文档章节

JAVA--基础前言开发

李文杰-Xx
 李文杰-Xx
发布于 2019/11/13 23:08
字数 1323
阅读 432
收藏 0

行业解决方案、产品招募中!想赚钱就来传!>>>

 

    Day12【Collection集合、ArrayList集合】练习题

基础题

练习一:集合框架

一、请简述集合框架。

答:集合框架主要包括两种:一种是集合,存储对象信息,另一种是Map.存储的是键值。

练习二:Collection集合统计元素出现次数

二、给定以下代码,请定义方法public static int listTest(Collection<String> list,String s)统计集合中指定元素出现的次数,如"a":2,"b": 2,"c" :1, "xxx":0。

                   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"));     

   Collection<String> list = new ArrayList<>();

        list.add("a");

        list.add("a");

        list.add("b");

        list.add("b");

        list.add("c");

        int  a=listTest(list,"a");

        int  b=listTest(list,"b");

        int  c=listTest(list,"c");

        int  ss=listTest(list,"xxx");

        System.out.println("a出现的次数:"+a);

        System.out.println("b出现的次数:"+b);

        System.out.println("c出现的次数:"+c);

        System.out.println("xxx出现的次数:"+ss);

 

    }

    public static int listTest(Collection<String>list2,String s){

        int count=0;

        Iterator  ss=list2.iterator();

        while (ss.hasNext()){

            if(s.equals(ss.next())){

                count++;

            }

        }

         return count;

    }

}

 

练习三:Collection集合数组转集合

三、定义一个方法,要求此方法把int数组转成存有相同元素的集合(集合里面的元素是Integer),并返回。

public class Exercise02 {

    public static void main(String[] args) {

        int[]aa={1,34,45,56,77,78,90};

        Meth(aa);

    }

    public   static  void Meth(int[]aa){

        Collection<Integer>list=new ArrayList<>();

        for(int  srg:aa){

            list.add(srg);

        }

        Iterator   ss=list.iterator();

          while (ss.hasNext()){

              System.out.println(ss.next());

          }

 

    }

}

 

 

练习四:Collection集合集合转数组

四、定义一个集合,并把集合(集合里面的元素是Integer)转成存有相同元素的数组,并将结果输出在控制台。(可以使用Object[]数组类型接收转换的数组)

//Collection集合集合转数组

public class Exercise03 {

    public static void main(String[] args) {

        Collection ss=new ArrayList();

        ss.add("刘备");

        ss.add("关羽");

        ss.add("张飞");

        ss.add("赵云");

        ss.add("黄忠");

        ss.add("马超");

        ss.add("卧龙");

        ss.add("凤雏");

     //集合转数组

        Object[]obj=ss.toArray();

        for(Object srg:obj){

            System.out.println(srg);

        }

    }

}

 

练习五:Collection集合contains()方法使用

五、定义一个方法listTest(ArrayList<String> al, String s),要求使用contains()方法判断al集合里面是否包含s。

public class Exercise04 {

    public static void main(String[] args) {

        ArrayList<String>ss=new ArrayList<>();

        ss.add("刘备");

        ss.add("关羽");

        ss.add("张飞");

        ss.add("赵云");

        ss.add("黄忠");

        ss.add("马超");

        ss.add("卧龙");

        ss.add("凤雏");

        boolean flag=listTest(ss,"张飞");

        System.out.println(flag);

    }

    public  static boolean listTest(ArrayList<String> al, String s){

        //boolean contains(Object o)如果此列表包含指定的元素,则返回 true 。

          for(String  srf:al){

              if(srf.contains(s)){

                  return true;

              }

          }

          return false;

    }

}

 

 

练习六:Collection集合isEmpty()方法的使用

六、定义一个方法listTest(ArrayList<String> al), 要求使用isEmpty()判断al里面是否有元素。

   ArrayList<String>ss=new ArrayList<>();

        ss.add("刘备");

        ss.add("关羽");

        ss.add("张飞");

        ss.add("赵云");

        ss.add("黄忠");

        ss.add("马超");

        ss.add("卧龙");

        boolean  flag=listTest(ss);

        System.out.println(flag);

    }

    public static boolean listTest(ArrayList<String> al){

        for(String  ss:al){

            //如果为空就返回true

            if(ss.isEmpty()){

                return true;

            }

        }

        return false;

    }

}

 

 

练习七:简述迭代器的实现原理

七、请简述迭代器的实现原理

当遍历集合时,首先通过调用集合的 iterator()方法获取迭代器对象,然后使用 hashNext()方 法判断集合中是否存在下一个元素。如果存在,则调用 next()方法将元素取出,否则说明已经到达了集合末尾,停止遍历元素。Iterator 迭代器对象在遍历集合时,内部采用指针的方式来跟踪集合中的元素,为了更好的理解迭代器的工作原理.

练习八:Collection集合返回首次出现索引

八、定义一个方法listTest(ArrayList<Integer> al, Integer s),要求返回s在al里面第一次出现的索引,如果s没出现过返回-1。

public static void main(String[] args) {

     ArrayList<Integer>list=new ArrayList<>();

        list.add(100);

        list.add(200);

        list.add(300);

        list.add(400);

        list.add(500);

        listTest(list,300);

    }

    public static  void listTest(ArrayList<Integer>al, Integer s){

         System.out.println(al.indexOf(s));

    }

 

扩展题

练习九:Collection集合练习

九、(复杂,并不难)定义一个学生类Student,包含三个属性姓名、年龄、性别,创建三个学生对象存入ArrayList集合中。

A:遍历集合遍历输出。

B:求出年龄最大的学生,然后将该对象的姓名变为:小猪佩奇。

   //存入ArrayList集合

       ArrayList<Student> list=new ArrayList<>();

        //创建对象

        Student  student1=new Student();

        student1.setName("李文杰");

        student1.setAge(23);

        student1.setSex("男");

        Student  student2=new Student();

        student2.setName("桑凤娇");

        student2.setAge(20);

        student2.setSex("女");

        Student  student3=new Student();

        student3.setName("郭朝旭");

        student3.setAge(27);

        student3.setSex("男");

        //添加到集合中

        list.add(student1);

        list.add(student2);

        list.add(student3);

        int  index=0;

        //默认下标为零的最大

        int num=list.get(0).getAge();

        for(int  i=0;i<list.size();i++){

          if(num<list.get(i).getAge()){

              num=list.get(i).getAge();

              index=i;

          }

       }

        System.out.println(num);

        list.get(index).setName("张三");

        System.out.println(list.get(index).getName());

      

    }

  

 

练习十:Collection集合练习

十、产生10个1-100的随机数,并放到一个数组中,把数组中大于等于10的数字放到一个list集合中,并打印到控制台。

public class Exercise08 {

    public static void main(String[] args) {

        Meth();

    }

    public  static void Meth(){

        ArrayList<Integer>list=new ArrayList<>();

        int[]num=new int[10];

        Random  ss=new Random();

        for(int  i=0;i<10;i++){

            //把随机生成的10 个数放数组中

            num[i]=ss.nextInt(100);

            if(num[i]>=10){

               list.add(num[i]);

            }

        }

       for(Integer ff:list){

           System.out.println(ff);

       }

    }

}

 

李文杰-Xx
粉丝 5
博文 68
码字总数 141909
作品 0
东城
后端工程师
私信 提问
加载中
请先登录后再评论。
Netty那点事(三)Channel与Pipeline

Channel是理解和使用Netty的核心。Channel的涉及内容较多,这里我使用由浅入深的介绍方法。在这篇文章中,我们主要介绍Channel部分中Pipeline实现机制。为了避免枯燥,借用一下《盗梦空间》的...

黄亿华
2013/11/24
2W
22
浅入浅出Android(003):使用TextView类构造文本控件

基础: TextView是无法供编辑的。 当我们新建一个项目MyTextView时候,默认的布局(/res/layout/activity_main.xml)中已经有了一个TextView: <TextView 运行效果如下: 修改其文本内容...

樂天
2014/03/22
619
1
beego API开发以及自动化文档

beego API开发以及自动化文档 beego1.3版本已经在上个星期发布了,但是还是有很多人不了解如何来进行开发,也是在一步一步的测试中开发,期间QQ群里面很多人都问我如何开发,我的业余时间实在...

astaxie
2014/06/25
2.7W
22
程序猿媛一:Android滑动翻页+区域点击事件

滑动翻页+区域点击事件 ViewPager+GrideView 声明:博文为原创,文章内容为,效果展示,思路阐述,及代码片段。文尾附注源码获取途径。 转载请保留原文出处“http://my.oschina.net/gluoyer...

花佟林雨月
2013/11/09
4.2K
1
代码生成器--Codgen

Codgen是一个基于数据库元数据模型,使用freemarker模板引擎来构建输出的代码生成器。freemarker的数据模型结构通常来说都是一个Map树状结构模型,codgen也不例外,它的数据模型这棵树的根节...

黄天政
2013/01/29
1.4W
2

没有更多内容

加载失败,请刷新页面

加载更多

什么是移动语义? - What is move semantics?

问题: I just finished listening to the Software Engineering radio podcast interview with Scott Meyers regarding C++0x . 我刚刚结束了对Scott Meyers进行的有关C ++ 0x的Software En......

技术盛宴
今天
24
0
算法与数据结构体系课

算法与数据结构体系课【超清原画】 下载地址:百度云盘 从0到工作5年,面试、进大厂、搭建知识体系、拓展技术上限 你不再需要其它算法与数据结构课程了 为什么学算法已经是一个不应该问的问题...

1930133570
今天
21
0
如何停止跟踪并忽略对Git中文件的更改? - How to stop tracking and ignore changes to a file in Git?

问题: I have cloned a project that includes some .csproj files. 我已经克隆了一个包含一些.csproj文件的项目。 I don't need/like my local csproj files being tracked by Git (or bei......

富含淀粉
今天
25
0
Redis阻塞

可能存在问题 内在原因:API或数据结构使用不合理、CPU饱和、持久化阻塞等 外在原因:CPU竞争、内存交换、网络问题等 问题处理: API或数据结构使用不合理,可能存在慢查询或者大对象: 发现...

游泳鸟
今天
17
0
OSChina 周五乱弹 —— 来人,上幼儿园老师跳舞的图!

Osc乱弹歌单(2020)请戳(这里) 【今日歌曲】 小小编辑:《奇跡の海》- 坂本真綾 《奇跡の海》- 坂本真綾 手机党少年们想听歌,请使劲儿戳(这里) 巴蜀(@巴拉迪维)最近有点闹心了, @巴...

小小编辑
今天
64
1

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部