题目1
假如你有3个室友,请使用HashSet集合保存3个室友的信息;
信息如下:
赵丽颖,18
范冰冰,20
杨幂,19
要求:
1:室友以对象形式存在,包含姓名和年龄两个属性;
2:使用代码保证集合中同名同年龄的对象只有一份;(相同姓名和年龄的对象认为是同一个对象)
效果:
参考答案:
public class ShiYou {
private String name;
private int a;
--自己补上构造方法,getter/setter方法,toString,hashCode和equals方法--
}
public class Test{
public static void main(String[] args) {
HashSet<ShiYou> set = new HashSet<>();
ShiYou sy1 = new ShiYou("赵丽颖",18);
ShiYou sy2 = new ShiYou("范冰冰",20);
ShiYou sy3 = new ShiYou("杨幂",19);
ShiYou sy4 = new ShiYou("赵丽颖",18);//虽然sy1和sy4的地址值不一样,但是内容一样,所以HashSet会认为这是重复的数据,不会添加的!
set.add(sy1);
set.add(sy2);
set.add(sy3);
set.add(sy4);//重复的数据,无法成功添加!!!
System.out.println("我的室友是:"+set);
}
}
题目2
请使用HashMap集合保存街道两旁的店铺名称;使用门牌号作为键,店铺名作为值,然后使用三种方式遍历输出;
信息如下:
101,阿三面馆
102,阿四粥馆
103,阿五米馆
104,阿六快递
要求:
1:键是整数,值是字符串;
2:输出的信息使用"–"链接
效果:
参考答案:
public static void main(String[] args) {
HashMap<Integer,String> map = new HashMap<>();
//添加信息
map.put(101,"阿三面馆");
map.put(102,"阿四粥馆");
map.put(103,"阿五米馆");
map.put(104,"阿六快递");
//方式1遍历 键找值
Set<Integer> set = map.keySet();
System.out.println("方式1遍历 键找值");
for (Integer key : set) {
System.out.println(key+"--"+map.get(key));
}
System.out.println("===================");
//方式2遍历 键值对对象
Set<Map.Entry<Integer, String>> en = map.entrySet();
System.out.println("方式2遍历 键值对对象");
for (Map.Entry<Integer, String> e : en) {
System.out.println(e.getKey()+"--"+e.getValue());
}
System.out.println("===================");
//方式3遍历 接口中默认的forEach方法配合lambda
System.out.println("方式3遍历 接口中默认的forEach方法配合lambda");
map.forEach((k,v)->{
System.out.println(k+"--"+v);
});
}
题目3(综合题,有难度)
请使用TreeMap集合保存劳模信息,要求以劳模对象为键,家庭住址为值,并按照劳模的年龄从大到小排序后输出;
信息如下:
18岁的张三,北京
20岁的李四,上海
35岁的王五,天津
21岁的赵六,北京
19岁的田七,上海
要求:
1:劳模类中有姓名和年龄两个属性;
2:添加上述信息后,使用代码删除张三的信息
3:添加上述信息后,使用代码修改李四的家庭住址为郑州
4:使用至少两种方式遍历集合中的信息并输出;
效果:
参考答案:
public class Person{
private String name;
private int age;
//注意这个toString方法,进行了修改,以保证在测试类中的打印效果;
@Override
public String toString() {
return age+"岁的"+name;
}
--自己补上构造方法,getter/setter方法--
}
public static void main(String[] args) {
//注意如果没有让Person类实现自然排序接口,那么就需要创建TreeMap对象的时候,写自定义排序规则
//且TreeMap集合并不依赖对象的hashCode方法和equals方法,因此学生类中hashCode方法和equals方法写不写都行;
//但是如果是HashMap集合,就必须写;
TreeMap<Person,String> map = new TreeMap<>((p1,p2)->{
//降序排列,所以使用p2的年龄减去p1的年龄
int i = p2.getAge() - p1.getAge();//主要条件
return i==0?p1.getName().compareTo(p2.getName()):i;//次要条件
});
//创建对象,添加信息
Person p1 = new Person("张三",18);
Person p2 = new Person("李四",20);
Person p3 = new Person("王五",35);
Person p4 = new Person("赵六",21);
Person p5 = new Person("田七",19);
//添加信息
/*
18岁的张三,北京
20岁的李四,上海
35岁的王五,天津
21岁的赵六,北京
19岁的田七,上海
*/
map.put(p1,"北京");
map.put(p2,"上海");
map.put(p3,"天津");
map.put(p4,"北京");
map.put(p5,"上海");
//删除张三的信息
map.remove(p1);//p1就是张三对象
//修改李四的家庭住址为郑州
map.put(p2,"郑州");//p2就是李四对象
//方式1遍历 键找值
Set<Person> set = map.keySet();
System.out.println("方式1遍历 键找值");
for (Person key : set) {
//因为重写了toString方法,所以可以直接打印 key
System.out.println(key+"--"+map.get(key));
}
System.out.println("===================");
//方式2遍历 键值对对象
Set<Map.Entry<Person, String>> en = map.entrySet();
System.out.println("方式2遍历 键值对对象");
for (Map.Entry<Person, String> e : en) {
System.out.println(e.getKey()+"--"+e.getValue());
}
System.out.println("===================");
//方式3遍历 接口中默认的forEach方法配合lambda
System.out.println("方式3遍历 接口中默认的forEach方法配合lambda");
map.forEach((k,v)->{
System.out.println(k+"--"+v);
});
}