集合练习题重点_第1页
集合练习题重点_第2页
集合练习题重点_第3页
集合练习题重点_第4页
集合练习题重点_第5页
已阅读5页,还剩6页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、1. 填空Collection 接口的特点是元素是_对象_;List 接口的特点是元素_有_(有|无)顺序,_不可以_(可以|不可以)重复;Set 接口的特点是元素_无_(有|无)顺序,_可以_(可以|不可以)重复;Map 接口的特点是元素是_键值对_,其中_值_可以重复,_键_不可以重复。2. (List)有如下代码import java.util.*;public class TestListpublic static void main(String args)List list = new ArrayList();list.add(“Hello”);list.add(“World”);

2、list.add(1, “Learn”);list.add(1, “Java”);printList(list);public static void printList(List list)System.out.prinltn(list);要求:1) 把/1 处的代码补充完整,要求输出list 中所有元素的内容2) 写出程序执行的结果Hello Java Learn World3) 如果要把实现类由ArrayList 换为LinkedList,应该改哪里?ArrayList 和LinkedList 使用上有什么区别?实现上有什么区别?List list = new LinkedList();

3、LinkedList(更适用于频繁的插入、删除操作)4) 如果要把实现类由ArrayList 换为Vector,应该改哪里?ArrayList 和Vector 使用上有什么区别?实现上有什么区别?List list = new Vector();Vector(古老的实现类、线程安全的,但效率要低于ArrayList)3. (List)写出下面程序的运行结果import java.util.*;public class TestListpublic static void main(String args)List list = new ArrayList();list.add(“Hello”)

4、;list.add(“World”);list.add(“Hello”);list.add(“Learn”);list.remove(“Hello”);list.remove(0);for(int i = 0; i<list.size(); i+)System.out.println(list.get(i);World Learn4. (Set,List)import java.util.*;public class TestListSetpublic static void main(String args)List list = new ArrayList();list.add(“H

5、ello”);list.add(“Learn”);list.add(“Hello”);list.add(“Welcome”);Set set = new HashSet();set.addAll(list);System.out.println(set.size();选择正确答案AA 编译不通过B 编译通过,运行时异常C 编译运行都正常,输出3D 编译运行都正常,输出45. (List)已知有一个Worker 类如下:public class Worker private int age;private String name;private double salary;public Work

6、er ()public Worker (String name, int age, double salary) = name;this.age = age;this.salary = salary;public int getAge() return age;public void setAge(int age) this.age = age;public String getName() return name;public void setName(String name) = name;public double getSalary()return

7、 salary;public void setSalary(double salary)this.salary = salary;public void work()System.out.println(name + “ work”);完成下面的要求1) 创建一个List,在List 中增加三个工人,基本信息如下:姓名 年龄 工资zhang3 18 3000li4 25 3500wang5 22 3200ArrayList L=new ArrayList();L.add(new Worker(zhang3,18,3000);L.add(new Worker(li4,25,3500);L.add

8、(new Worker(wang5,22,3200);2) 在li4 之前插入一个工人,信息为:姓名:zhao6,年龄:24,工资3300L.add(1,new Worker(zhao6,24,330);3) 删除wang5 的信息L.remove(3);4) 利用for 循环遍历,打印List 中所有工人的信息先在Worker类中重写toString方法for(int i=0;i<L.size;i+)Syso(L.get(i);5) 利用迭代遍历,对List 中所有的工人调用work 方法。Iterator it=L.iterator();while(it.hasNext()Syste

9、m.out.println(it.next();6) 为Worker 类添加equals 方法public boolean equals(Object obj) if (this = obj)return true;if (obj = null)return false;if (getClass() != obj.getClass()return false;Worker other = (Worker) obj;if (age != other.age)return false;if (name = null) if ( != null)return false; els

10、e if (!name.equals()return false;return true;6. (Set,Hash 算法)为上一题的Worker 类,在添加完equals 方法的基础上,添加一个hashCode 方法。public int hashCode()/1有几种写法:1) return 0;2)int result = 0;if (name != null) result = name.hashCode();return result + age;3) return super.hashCode();现在要把Worker 类放入HashSet 中,并希望在HashS

11、et 中没有重复元素,则下面说法正确的是:CA. 三种写法都正确B. 1), 2)写法正确,2)效率更高C. 2)写法正确,1),3)写法都不正确7. (Set,Hash 算法,方法覆盖)代码改错import java.util.*;class WorkerString name;int age;double salary;public Worker()public Worker(String name, int age, double salary) = name;this.age = age;this.salary = salary;public int hashCode

12、() /重写父类方法,权限不能小于父类return name.hashCode() + age + salary;public boolean equals(Worker w)if ( = name && w.salary = salary && w.age = age)return true;else return false;public class TestWorkerpublic static void main(String args)Set set = new HashSet();set.add(new Worker(“tom”, 18,

13、 2000);set.add(new Worker(“tom”, 18, 2000);set.add(0, new Worker(“jerry”, 18, 2000);/ HashSet是无序的集合,不能在指定位置添加System.out.println(set.size();8. (Set,Hash 算法)在前面的Worker 类基础上,为Worker 类增加相应的方法,使得Worker放入HashSet 中时,Set 中没有重复元素。并编写相应的测试代码。9. (Set,Comparable 接口)在前面的Worker 类基础上,为Worker 类添加相应的代码,使得Worker 对象能正

14、确放入TreeSet 中。并编写相应的测试代码。注:比较时,先比较工人年龄大小,年龄小的排在前面。如果两个工人年龄相同,则再比较其收入,收入少的排前面。如果年龄和收入都相同,则根据字典顺序比较工人姓名。例如:有三个工人,基本信息如下:姓名 年龄 工资zhang3 18 1500li4 18 1500wang5 18 1600zhao6 17 2000放入TreeSet 排序后结果为:zhao6 li4 zhang3 wang510. (Map)关于下列Map 接口中常见的方法put 方法表示放入一个键值对,如果键已存在则_,如果键不存在则_。remove 方法接受_个参数,表示_。get 方法

15、表示_,get 方法的参数表示_,返回值表示_。要想获得Map 中所有的键,应该使用方法_,该方法返回值类型为_。要想获得Map 中所有的值,应该使用方法_,该方法返回值类型为_。要想获得Map 中所有的键值对的集合,应该使用方法_,该方法返回一个_类型所组成的Set。11. (Map)利用Map,完成下面的功能:从命令行读入一个字符串,表示一个年份,输出该年的世界杯冠军是哪支球队。如果该年没有举办世界杯,则输出:没有举办世界杯。附:世界杯冠军以及对应的夺冠年份,请参考本章附录。12. (Map)已知某学校的教学课程内容安排如下:完成下列要求:1) 使用一个Map,以老师的名字作为键,以老师教

16、授的课程名作为值,表示上述课程安排。2) 增加了一位新老师Allen 教JDBC3) Lucy 改为教CoreJava4) 遍历Map,输出所有的老师及老师教授的课程5) *利用Map,输出所有教JSP 的老师。13. (泛型)使用泛型,改写第5 题14. (泛型)使用泛型和Map.Entry 接口,改写第12 题的前4 问15. *(List)写出下面程序的输出结果import java.util.*;class MyClassint value;public MyClass()public MyClass(int value) this.value = value; public Stri

17、ng toString()return “”+value;public class TestListpublic static void main(String args)MyClass mc1 = new MyClass(10);MyClass mc2 = new MyClass(20);MyClass mc3 = new MyClass(30);List list = new ArrayList();list.add(mc1);list.add(mc2);list.add(mc3);MyClass mc4 = (MyClass) list.get(1);mc4.value = 50;for

18、(int i = 0; i<list.size(); i+)System.out.println(list.get(i);16. *(Set,HashSet,空指针)有下面代码import java.util.*;class Student int age;String name;public Student()public Student(String name, int age) = name;this.age = age;public int hashCode()return name.hashCode() + age;public boolean equals(

19、Object o)if (o = null) return false;if (o = this) return true;if (o.getClass() != this.getClass() return false;Student stu = (Student) o;if (.equals(name) && stu.age = age) return true;else return false;public class TestHashSetpublic static void main(String args)Set set = new HashSet

20、();Student stu1 = new Student();Student stu2 = new Student(“Tom”, 18);Student stu3 = new Student(“Tom”, 18);set.add(stu1);set.add(stu2);set.add(stu3);System.out.println(set.size();下列说法正确的是:A. 编译错误B. 编译正确,运行时异常C. 编译运行都正确,输出结果为3D. 编译运行都正确,输出结果为217. *(Set)有如下两个类(只写了类的属性,请自行添加相应的构造方法和get/set 方法)要求,完善Wor

21、ker 和Address 类,使得Worker 对象能够正确放入HashSet 中:即将Worker 放入HashSet 中时不会出现重复元素。并编写相应测试代码。18. *(Map)在原有世界杯Map 的基础上,增加如下功能:读入一支球队的名字,输出该球队夺冠的年份列表。例如,读入“巴西”,应当输出1958 1962 1970 1994 2002读入“荷兰”,应当输出没有获得过世界杯19. *(Map)设计Account 对象如下:要求完善设计,使得该Account 对象能够自动分配id。给定一个List 如下:List list = new ArrayList();list.add(new

22、 Account(10.00, “1234”);list.add(new Account(15.00, “5678”);list.add(new Account(0, “1010”);要求把List 中的内容放到一个Map 中,该Map 的键为id,值为相应的Account 对象。最后遍历这个Map,打印所有Account 对象的id 和余额。20. *(List)写一个函数reverseList,该函数能够接受一个List,然后把该List 倒序排列。例如:List list = new ArrayList();list.add(“Hello”);list.add(“World”);list

23、.add(“Learn”); /此时list 为Hello World LearnreverseList(list);/调用reverseList 方法之后,list 为Learn World Hello21. *(Map,Hash 算法)有如下代码:import java.util.*;class MyKeyint keyValue;public MyKey()public MyKey(int value)this.keyValue = value;class MyValueString value;public MyValue()public MyValue(String value)th

24、is.value = value;public String toString()return value;public class TestMappublic static void main(String args)Map map = new HashMap();MyKey key1 = new MyKey(10);map.put(key1, new MyValue(“abc”);map.put(new MyKey(10), new MyValue(“cde”);System.out.println(map.get(key1);System.out.println(map.size();写

25、出该代码的输出结果。22. *(Id,hashCode,equals)为Worker 类增加id 属性,用来唯一标识一个员工。即:如果员工的id 不同,则不管其姓名、年龄、工资是否相同,都认为是不同的员工。部分代码如下:class Workerprivate final Long id;private String name;private double salary;private int age;/构造方法/get/set 方法public boolean equals(Object obj)/1 此处仅判断id 是否相同public int hashCode()/2 此处返回hashCode要求:1) 完善构造方法和get/set 方法。要求自动分配Worker 的id2) 完善equals 方法。要求仅判断id 是否相同3) /2 处,如果写成return (int)(name.hashCode() + id.hashCode() + age + salary);是否正确?为什么?23. *(综合)有如下Student 对象其中,classNum 表示学生的班号,例如“class05”。有如下ListList list = new ArrayList();list.add(new Student(“Tom”, 18, 100, “class05”

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论