Java中进阶集合的六道综合练习

案例一->自动点名器1:

题解:

package com.qiong.test;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Random;

public class Test1 {
    public static void main(String[] args) {
        /*
        班里有n个学生,实现随机点名器
         */
        
        //1.创建集合并添加数据
        ArrayList<String> list = new ArrayList<>();
        Collections.addAll(list,"zhangsan","lisi","wangwu","zhaoliu","liuqi");
        
        //2.生成随机索引
        Random r = new Random();
        int index = r.nextInt(list.size());
        
        //3.输出学生
        System.out.println(list.get(index));
    }
}

案例二->自动点名器2:

题解:

package com.qiong.test;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Random;

public class Test2 {
    public static void main(String[] args) {
        /*
        自动点名器2
            班级里有N个学生
            要求:
            70%的概率随机到男生
            30%的概率随机到女生
         */

        //创建学生对象
        Student s1 = new Student("张无忌", "男");
        Student s2 = new Student("赵敏", "女");
        Student s3 = new Student("小龙女", "女");
        Student s4 = new Student("张三丰", "男");
        Student s5 = new Student("杨逍", "男");

        //创建集合并添加元素
        ArrayList<Student> list = new ArrayList<>();
        Collections.addAll(list, s1, s2, s3, s4, s5);

        Random r = new Random();
        int temp = r.nextInt(10) + 1;
        Student s = new Student();
        while (true){
            s = stu(list);
            if(temp < 8){
                if(s.getGender().equals("男")){
                    break;
                }
            }else {
                if(s.getGender().equals("女")){
                    break;
                }
            }
        }

        System.out.println(s);

    }

    //随机一个学生对象
    public static Student stu(ArrayList<Student> list){
        Random r = new Random();
        int index = r.nextInt(list.size());
        return list.get(index);
    }
}

案例三->自动点名气3:

题解:

package com.qiong.test;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Random;
import java.util.Scanner;

public class Test3 {
    public static void main(String[] args) {
        /*
        自动点名器3
            班级里有N个学生
            要求:
            被点到的学生不会再被点到。
            但是如果班级中所有的学生都点完了,需要重新开启第二轮点名。
         */

        //创建集合并添加元素
        ArrayList<String> list = new ArrayList<>();
        Collections.addAll(list, "张无忌", "杨逍", "赵敏", "小龙女", "张三丰");

        //创建临时集合用来每轮的点名
        ArrayList<String> temp = new ArrayList<>(list);

        //生成随机索引,输出学生姓名
        Random r = new Random();
        Scanner sc = new Scanner(System.in);
        while (true) {
            if (temp.addAll(list)) {
                System.out.println("重新开始一轮点名");
            }
            System.out.println("输入-1代表结束点名,否则继续点名");
            String s = sc.nextLine();
            if (s.equals("-1")) {
                break;
            }
            int index = r.nextInt(temp.size());
            System.out.println(temp.get(index));
            temp.remove(temp.get(index));

        }
    }
}

案例四->Map集合案例-省和市

题解:

package com.qiong.test;

import java.util.HashMap;
import java.util.function.BiConsumer;

public class Test6 {
    public static void main(String[] args) {
        /*
        Map集合案例-省和市
        需求
            定义一个Map集合,键用表示省份名称province,值表示市city,但是市会有多个。
            添加完毕后,遍历结果格式如下:
            江苏省=南京市,扬州市,苏州市,无锡市,常州市
            湖北省=武汉市,孝感市,十堰市,宜昌市,鄂州市
            河北省=石家庄市,唐山市,邢台市,保定市,张家口市
         */

        HashMap<String,String[]> hm = new HashMap<>();

        String[] s1 = {"南京市","扬州市","苏州市","无锡市","常州市"};
        String[] s2 = {"武汉市","孝感市","十堰市","宜昌市","鄂州市"};
        String[] s3 = {"石家庄市","唐山市","邢台市","保定市","张家口市"};

        hm.put("江苏省", s1);
        hm.put("湖北省", s2);
        hm.put("河北省", s3);

        hm.forEach((String s, String[] strings) -> {
                StringBuilder str = new StringBuilder();
                for (int i = 0; i < strings.length; i++) {
                    if(i == strings.length - 1){
                        str.append(strings[i]);
                        break;
                    }
                    str.append(strings[i]).append(",");
                }
                System.out.println(s + " = " + str);
            }
        );
    }
}

  • 6
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
用来完成大作业的。文档内容: 1 Java技术体系 1.1 Java语言 1.2 Java平台 1.3 Java应用领域 2 Java语言的技术特点 2.1 1 2.2 2 2.3 3 3 Java语言与C++的异同分析总结。 4 选用C和java语言时编程算法程序有什么不同,有什么优势和劣势。 5 自己编程学习的级别和状态。以及自己以后的编程学习的计划和想法。 6 下面3道选一道,给出算法分析和程序。 1)“黄金分割数”在我们的生活很常见,但是在不同的应用领域,要求的精度也不一样。 例如:三位小数是0.618 现在我们需要你能求出保留100位小数的黄金分割数,采用的算法为“分层计算法”: 黄金数= 1 --------------- 1+ 1 ------------- 1+ 1 ----------- 1+ 1 --------- ..... 注意,计算出的结果,如果第100位为0也需要保留。 2)已知一个数列: 5,2,4,3,7,6 那么,在这个数列存在这样一些“连续数”,例如:5,2,4,3这个子数列排序后是连续的。同样2,4,3也是连续的,为了方便表示 我们使用下标来标识,这样,这个数列存在以下“连续数”: [1,1] [1,4] [1,6] [2,2] [2,4] [3,3] [3,4] [4,4] [5,5] [5,6] [6,6] 这样,他就存在11个“连续数”。现在需要你在用户找出一个数组所有的“连续数”。 要求: 1、用户输入一个整数N,表示下面数组的个数 2、用户每输入一行作为一个数组 如: 用户输入: 1 5,2,4,3,7,6 程序输出: 11 3)有一种数我们称之为幸运数,它的特点是这样的,首先,由自然数按顺序排列: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 … 这样,1比较特殊, 1为第一个幸运数,那么,我们移除掉序号能被2整除的数(注意:是序号,而不是数本身,每次移除后都重新排序)就剩下: 1 3 5 7 9 11 13 15 17 19… 3为第二个幸运数,那么我们需要去掉序号能被3(下一次是除4,然后是5,每次加1)整除的数,5 11 17...剩下: 1 3 7 9 13 15 19… 那么7为第三个幸运数,后面的幸运数,依此类推,移除之后剩下的数字都是幸运数。 现在我们需要你求出给定的m和n之间的幸运数的个数: 例如:给定1 20,那么个数为:5(5个幸运数分别是1,3,7,13,19) 现在要求用户输入两个数m和n(m<n<=1000*1000),输出幸运数的个数。 例如: 用户输入: 1 20 程序输出: 5 格式:小四,1.5倍行距

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值