网站首页 > 技术文章 正文
基础题
练习一:集合框架
一、请简述集合框架。
集合按照其存储结构可以分为两大类,分别是单列集合java.util.Collection和双列集合java.util.Map。
Collection:单列集合类的根接口,用于存储一系列符合某种规则的元素,它有两个重要的子接口,分别是java.util.List和java.util.Set。其中,List的特点是元素有序、元素可重复。Set的特点是元素无序,而且不可重复。List接口的主要实现类有java.util.ArrayList和java.util.LinkedList,Set接口的主要实现类有java.util.HashSet和java.util.TreeSet。
练习二:Collection集合统计元素出现次数
二、给定以下代码,请定义方法listTest()统计集合中指定元素出现的次数,如"a": 2,“b”: 2,“c” :1, “xxx”:0。
public class CollectionTest01{ public static void main(String[] args) { Collection<String> list = new ArrayList<>(); list.add("a"); list.add("a"); list.add("b"); list.add("b"); list.add("c"); System.out.println("a:"+listTest(list, "a")); System.out.println("b:"+listTest(list, "b")); System.out.println("c:"+listTest(list, "c")); System.out.println("xxx:"+listTest(list, "xxx")); } //定义方法统计集合中指定元素出现的次数 public static int listTest(Collection<String> list,String s){ //定义计数器,初始化为0 int count = 0; //增强for遍历集合 for (String string : list) { //判断传入方法的字符与遍历集合的是否一致 if (s.equals(string)) { //如果一致,加1 count++; } } return count; } }
练习三:Collection集合数组转集合
三、定义一个方法,要求此方法把int数组转成存有相同元素的集合(集合里面的元素是Integer),并返回。()
public class CollectionTest02 { public static void main(String[] args) { //定义int数组 int[] arr = {1,2,3,4,5}; ArrayList<Integer> list = listTest(arr); System.out.println(list); } public static ArrayList<Integer> listTest(int[] arr) { //定义集合 ArrayList<Integer> list = new ArrayList<Integer>(); //遍历数组,把元素依次添加到集合当中 for (int a : arr) { list.add(a); } return list; } }
练习四:Collection集合集合转数组
四、定义一个集合,并把集合(集合里面的元素是Integer)转成存有相同元素的数组,并将结果输出在控制台。(可以使用Object[]数组类型接收转换的数组)
public class CollectionTest03 { public static void main(String[] args) { //定义集合,添加数据 ArrayList<Integer> list = new ArrayList<Integer>(); list.add(100); list.add(200); list.add(300); //Object[] toArray()转换成一个Object数组 Object[] obj = list.toArray(); // 遍历数组 for (int i = 0; i < obj.length; i++) { System.out.println(obj[i]); } } }
练习五:Collection集合contains()方法使用
五、定义一个方法listTest(ArrayList al, String s),要求使用contains()方法判断al集合里面是否包含s。
public class CollectionTest04 { public static void main(String[] args) { //定义集合,添加数据 ArrayList<String> list = new ArrayList<String>(); list.add("itcast"); list.add("itheima"); list.add("java"); System.out.println(listTest(list,"java")); } public static boolean listTest(ArrayList<String> al, String s) { //判断s是否在集合中存在,存在返回true,不存在返回false if (al.contains(s)) { return true; } return false; } }
练习六:Collection集合isEmpty()方法的使用
六、定义一个方法listTest(ArrayList al), 要求使用isEmpty()判断al里面是否有元素。
public class CollectionTest05 { public static void main(String[] args) { //定义集合,添加数据 ArrayList<String> list = new ArrayList<String>(); list.add("1"); System.out.println(listTest(list)); } public static boolean listTest(ArrayList<String> al) { //判断al集合是否为空,为空返回true,不为空返回false if(al.isEmpty()){ return true; } return false; } }
练习七:简述迭代器的实现原理
七、请简述迭代器的实现原理
当遍历集合时,首先通过调用集合的iterator()方法获得迭代器对象,然后使用hashNext()方法判断集合中是否存在下一个元素,如果存在,则调用next()方法将元素取出,否则说明已到达了集合末尾,停止遍历元素。
Iterator迭代器对象在遍历集合时,内部采用指针的方式来跟踪集合中的元素,在调用Iterator的next()方法之前,迭代器的索引位于第一个元素之前,不指向任何元素,当第一次调用迭代器的next方法后,迭代器的索引会向后移动一位,指向第一个元素并将该元素返回,当再次调用next方法时,迭代器的索引会指向第二个元素并将该元素返回,依此类推,直到hasNext方法返回false,表示到达了集合的末尾,终止对元素的遍历。
练习八:Collection集合返回首次出现索引
八、定义一个方法listTest(ArrayList al, Integer s),要求返回s在al里面第一次出现的索引,如果s没出现过返回-1。
public class CollectionTest06 { public static void main(String[] args) { //定义集合,添加数据 ArrayList<Integer> list = new ArrayList<Integer>(); list.add(1); list.add(2); list.add(3); list.add(4); list.add(5); System.out.println(listTest(list, 5)); } public static int listTest(ArrayList<Integer> al, Integer s) { //遍历集合,获取元素,判断元素是否与s相等,相等返回索引 for (int i = 0; i < al.size(); i++) { if (al.get(i).equals(s)) { return i; } } return -1; } }
猜你喜欢
- 2024-10-08 java常用数据判空、比较和类型转换
- 2024-10-08 集合框架-ArrayList源码分析(java集合框架源码解析)
- 2024-10-08 大数据编程入门:Java ArrayList(java大数据视频教程)
- 2024-10-08 Python开发入门之列表-List(python列表的基本操作编程)
- 2024-10-08 如何在python各种列表中求最值?(如何在python各种列表中求最值的方法)
- 2024-10-08 List接口常用方法(list接口的常用方法)
- 2024-10-08 Python语法基础(6)集合(python中的集合)
- 2024-10-08 Java初学者学习任务总结「15」(java学习知识点路线)
- 2024-10-08 Sonar代码规范分析(sonar代码扫描规则及解决方案)
- 2024-10-08 最详细集合源码解析之ArrayList集合源码解析
- 10-02基于深度学习的铸件缺陷检测_如何控制和检测铸件缺陷?有缺陷铸件如何处置?
- 10-02Linux Mint 22.1 Cinnamon Edition 搭建深度学习环境
- 10-02AWD-LSTM语言模型是如何实现的_lstm语言模型
- 10-02NVIDIA Jetson Nano 2GB 系列文章(53):TAO模型训练工具简介
- 10-02使用ONNX和Torchscript加快推理速度的测试
- 10-02tensorflow GPU环境安装踩坑日记_tensorflow配置gpu环境
- 10-02Keye-VL-1.5-8B 快手 Keye-VL— 腾讯云两卡 32GB GPU保姆级部署指南
- 10-02Gateway_gateways
- 最近发表
-
- 基于深度学习的铸件缺陷检测_如何控制和检测铸件缺陷?有缺陷铸件如何处置?
- Linux Mint 22.1 Cinnamon Edition 搭建深度学习环境
- AWD-LSTM语言模型是如何实现的_lstm语言模型
- NVIDIA Jetson Nano 2GB 系列文章(53):TAO模型训练工具简介
- 使用ONNX和Torchscript加快推理速度的测试
- tensorflow GPU环境安装踩坑日记_tensorflow配置gpu环境
- Keye-VL-1.5-8B 快手 Keye-VL— 腾讯云两卡 32GB GPU保姆级部署指南
- Gateway_gateways
- Coze开源本地部署教程_开源canopen
- 扣子开源本地部署教程 丨Coze智能体小白喂饭级指南
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (76)
- js判断是否是json字符串 (75)
- c语言min函数头文件 (77)
- asynccallback (87)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 无效的列索引 (74)