ImageVerifierCode 换一换
格式:DOCX , 页数:36 ,大小:25.27KB ,
资源ID:10131665      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/10131665.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(java集合框架习题与答案.docx)为本站会员(b****7)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

java集合框架习题与答案.docx

1、java集合框架习题与答案java 集合框架(习题)集合框架Key Point* Collection 接口、Set 接口、List 接口基本操作* List 接口及其实现类* Set 接口及其实现类* 迭代遍历* Hash 算法与hashCode 方法* Comparable 接口* Map 接口及其实现类* 遍历Map* 泛型练习1. 填空Collection 接口的特点是元素是对象;List 接口的特点是元素有(有|无)顺序,可以(可以|不可以)重复;Set 接口的特点是元素无(有|无)顺序,不可以(可以|不可以)重复;Map 接口的特点是元素是键值对,其中值可以重复,键不可以重复。2.

2、 (List)有如下代码import java.util.*;public class TestListpublic static void main(String args)List list = new ArrayList();list.add(“Hello”);list.add(“World”);list.add(1, “Learn”);list.add(1, “Java”);printList(list);public static void printList(List list)for(Object obj:list)String str=(String)obj;System.ou

3、t.println(obj);要求:1) 把/1 处的代码补充完整,要求输出list 中所有元素的内容2) 写出程序执行的结果 Hello java Learn World3) 如果要把实现类由ArrayList 换为LinkedList,应该改哪里?ArrayList 和LinkedList 使用上有什么区别?实现上有什么区别?把实例化的语句改为new LinkedList();ArrayList 数组实现 查询快 增删慢LinkedList 链表实现 查询慢 增删快4) 如果要把实现类由ArrayList 换为Vector,应该改哪里?ArrayList 和Vector 使用上有什么区别?

4、实现上有什么区别?ArrayList是线程不同步的,轻量级的,线程不安全,速度快 Vector是线程同步的 ,多线程访问比较安全,速度慢 3. (List)写出下面程序的运行结果import java.util.*;public class TestListpublic static void main(String args)List list = new ArrayList();list.add(“Hello”);list.add(“World”);list.add(“Hello”);list.add(“Learn”);list.remove(“Hello”);list.remove(0)

5、;for(int i = 0; ilist.size(); i+)System.out.println(list.get(i);HelloLearn4. (Set,List)import java.util.*;public class TestListSetpublic static void main(String args)List list = new ArrayList();list.add(“Hello”);list.add(“Learn”);list.add(“Hello”);list.add(“Welcome”);Set set = new HashSet();set.addA

6、ll(list);System.out.println(set.size();选择正确答案A 编译不通过B 编译通过,运行时异常C 编译运行都正常,/输出HashSet中不能放重复值D 编译运行都正常,输出45. (List)已知有一个Worker 类如下:public class Worker private int age;private String name;private double salary;public Worker ()public Worker (String name, int age, double salary)this.name = name;this.age

7、= 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) this.name = name;public double getSalary()return salary;public void setSalary(double salary)this.salary = salary;public void work(

8、)System.out.println(name + “ work”);完成下面的要求1) 创建一个List,在List 中增加三个工人,基本信息如下:姓名 年龄 工资zhang3 18 3000li4 25 3500wang5 22 32002) 在li4 之前插入一个工人,信息为:姓名:zhao6,年龄:24,工资33003) 删除wang5 的信息4) 利用for 循环遍历,打印List 中所有工人的信息5) 利用迭代遍历,对List 中所有的工人调用work 方法。6) 为Worker 类添加equals 方法6. (Set,Hash 算法)为上一题的Worker 类,在添加完equa

9、ls 方法的基础上,添加一个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 中,并希望在HashSet 中没有重复元素,则下面说法正确的是:A. 三种写法都正确B. 1), 2)写法正确,2)效率更高C. 2)写法正确,1),3)写法都不正确7. (Set,Hash 算法,方法覆盖)

10、代码改错import java.util.*;class WorkerString name;int age;double salary;public Worker()public Worker(String name, int age, double salary)this.name = name;this.age = age;this.salary = salary;public int hashCode()/hashCode必须声明为公共的。return (int)(name.hashCode() + age + salary);/返回值类型为整形(/equals方法实现有错public

11、 boolean equals(Worker w)if (w.name = 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, 2000);set.add(new Worker(“tom”, 18, 2000);set.add(0, new Worker(“jerry”, 18, 200

12、0);/HashSet中没有定义带下标的add方法。System.out.println(set.size();8. (Set,Hash 算法)在前面的Worker 类基础上,为Worker 类增加相应的方法,使得Worker放入HashSet 中时,Set 中没有重复元素。并编写相应的测试代码。class WorkerString name;int age;double salary;public Worker()public Worker(String name, int age, double salary)this.name = name;this.age = age;this.sal

13、ary = salary;public int hashCode()return (int)(name.hashCode() + age + salary); public boolean equals(Worker w)if (w.name = name & w.salary = salary & w.age = age)return true;else return false;9. (Set,Comparable 接口)在前面的Worker 类基础上,为Worker 类添加相应的代码,使得Worker 对象能正确放入TreeSet 中。并编写相应的测试代码。注:比较时,先比较工人年龄大小

14、,年龄小的排在前面。如果两个工人年龄相同,则再比较其收入,收入少的排前面。如果年龄和收入都相同,则根据字典顺序比较工人姓名。例如:有三个工人,基本信息如下:姓名 年龄 工资zhang3 18 1500li4 18 1500wang5 18 1600zhao6 17 2000放入TreeSet 排序后结果为:zhao6 li4 zhang3 wang5import java.util.HashSet; public class Test1 public static void main(String args) / TODO Auto-generated method stub HashSet

15、hs=new HashSet(); Worker w1=new Worker(zhang3, 18, 1500); Worker w2=new Worker(lis4,18,1500); Worker w3=new Worker(wang5,18,1600); Worker w4=new Worker(zhao6,17,2000); hs.add(w1); hs.add(w2); hs.add(w3); hs.add(w4); System.out.println(hs.size(); System.out.println(hs); class Worker implements Compar

16、able String name; int age; double salary; public Worker() public Worker(String name, int age, double salary) this.name = name; this.age = age; this.salary = salary; Override public int compareTo(Worker o) / TODO Auto-generated method stub if(this.age!=o.age) return this.age-o.age; else if(this.salar

17、y!=o.salary) /Integer integer1=new Integer(this.salary) return new Double(this.salary).compareTo(new Double(o.salary); else if(this.name.equals(o.name) return pareTo(o.name); return 0; Override public int hashCode() final int prime = 31; int result = 1; result = prime * result + age; result = prime

18、* result + (name = null) ? 0 : name.hashCode(); long temp; temp = Double.doubleToLongBits(salary); result = prime * result + (int) (temp (temp 32); return result; Override public boolean equals(Object obj) if (this = obj) return true; if (obj = null) return false; if (getClass() != obj.getClass() re

19、turn false; Worker other = (Worker) obj; if (age != other.age) return false; if (name = null) if (other.name != null) return false; else if (!name.equals(other.name) return false; if (Double.doubleToLongBits(salary) != Double .doubleToLongBits(other.salary) return false; return true; Override public

20、 String toString() / TODO Auto-generated method stub return age+/+salary+/+name; 10. (Map)关于下列Map 接口中常见的方法put 方法表示放入一个键值对,如果键已存在则新值替换旧值,如果键不存在则增加一个键值对。remove 方法接受一个参数,表示从映射中移除其映射关系的键。get 方法表示返回指定键所映射的值,get 方法的参数表示移除的其映射关系的键,返回值表示与key关联的值。要想获得Map 中所有的键,应该使用方法ketSet,该方法返回值类型为Set集合。要想获得Map 中所有的值,应该使用方法

21、get,该方法返回值类型为指定键所映射的值。要想获得Map 中所有的键值对的集合,应该使用方法entrySet,该方法返回一个Map.Entry类型所组成的Set。11. (Map)利用Map,完成下面的功能:从命令行读入一个字符串,表示一个年份,输出该年的世界杯冠军是哪支球队。如果该年没有举办世界杯,则输出:没有举办世界杯。附:世界杯冠军以及对应的夺冠年份,请参考本章附录。public class Bk18 public static void main(String args) / TODO Auto-generated method stub BufferedReader br=new

22、BufferedReader(new InputStreamReader(System.in); String year=null; try year=br.readLine(); catch (IOException e) / TODO Auto-generated catch block e.printStackTrace(); Map map=new HashMap(); map.put(2002, 巴西); map.put(2006, 意大利); map.put(2010,南非); if(map.containsKey(year) System.out.println(map.get(

23、year); else System.out.println(这一年没有承办世界杯!); 12. (Map)已知某学校的教学课程内容安排如下:集合框架(习题) o:button=t target=_blank href= src=file:/C:DOCUME1ADMINI1LOCALS1Tempmsohtmlclip101clip_image002.png完成下列要求:1) 使用一个Map,以老师的名字作为键,以老师教授的课程名作为值,表示上述课程安排。2) 增加了一位新老师Allen 教JDBC3) Lucy 改为教CoreJava4) 遍历Map,输出所有的老师及老师教授的课程5) *利用

24、Map,输出所有教JSP 的老师。public static void main(String args) / TODO Auto-generated method stub Map map=new TreeMap(); map.put(Tom, CoreJava); map.put(John, Oracle); map.put(Susan, Oracle); map.put(Jerry, JDBC); map.put(Jim, Unix); map.put(Kevin, JSP); map.put(Lucy, JSP); System.out.println(map.size(); map.

25、put(Allen, JSP); System.out.println(map.size(); map.remove(Lucy); map.put(Lucy, CoreJava); Set set=map.keySet(); for(Object obj:set) System.out.println(map.get(String)obj); for(String str:set) if(map.get(str).equals(JSP) System.out.println(教JSP的老师有:+str); 13. (泛型)使用泛型,改写第5 题package list; import java

26、.util.Iterator;import java.util.LinkedList; public class Test2 public static void main(String args) / TODO Auto-generated method stub LinkedList ll=new LinkedList(); Worker1 w1=new Worker1(zhang3,18,3000); Worker1 w2=new Worker1(li4,25,3500); Worker1 w3=new Worker1(wang5,22,3200); ll.add(w1); ll.add

27、(w2); ll.add(w3); ll.add(1, new Worker1(zhao6,24,2200); ll.remove(w3); /用for循环遍历 for(int i=0;ill.size();i+) System.out.println(ll.get(i); System.out.println(=); /用迭代器遍历 Iterator iterator=ll.iterator(); while(iterator.hasNext() System.out.println(iterator.next(); class Worker1 private int age; privat

28、e String name; private double salary; public Worker1 () public Worker1 (String name, int age, double salary) this.name = 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) this.name = name; public double getSalary() return salary; public

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1