打发时间

欢迎斧正

1、统计 int[] arr={1,4,1,4,2,5,4,5,8,77,88,5,4,9,6,2,4,1,5}中每个数字出现的次数

 @org.junit.Test
    public void test(){
        HashMap<Integer, Integer> hashMap=new HashMap<>();
        int[] arr={1,4,1,4,2,5,4,5,8,77,88,5,4,9,6,2,4,1,5};
        for (int i = 0; i < arr.length; i++) {
            if(hashMap.get(arr[i])==null){
                hashMap.put(arr[i],1);
            }else {
                hashMap.put(arr[i],hashMap.get(arr[i])+1);
            }
        }
        Set<Integer> integers = hashMap.keySet();
        for (Integer integer : integers) {
            System.out.println(integer+"出现"+hashMap.get(integer)+"次");
        }
    }

2、小明和小红去书店买同一本书,小明带的钱差4.98元,小红差1分钱,他俩的钱合起来还不够,问小明带多少钱,小红带多少钱,书的定价是多少

 String[] names = {"小明", "小红", "书价"};
        double[] arr = new double[3];
        //小明的钱
        for (int i = 0; ; i++) {
            //小红的钱
            for (int j = 0; j < i; j++) {
                //小明的钱加一分等于小红的钱加499分
                //两个人的钱加起来也不够
                if (i + 1 == j + 499 && i + j < i + 1 && i + j < j + 499) {
                    arr[0] = i / 100.0;
                    arr[1] = j / 100.0;
                    arr[2] = (i + 1) / 100.0;
                    for (int k = 0; k < arr.length; k++) {
                        System.out.println(names[k] + "是" + arr[k]);
                    }
                    return true;
                }

            }
        }

3、小张参加一个聚会,聚会中每个人都需要相互握手,他注意到大家总共需要握手45次,那么总共有多少人参加了聚会

定义一个方法求当人数为num时的握手次数

public static int shackMan(int num) {
        if (num < 2) {
            return 0;
        } else if (num == 2) {
            return 1;
        } else {
            return (num - 1) + shackMan(num - 1);
        }
    }

然后调用

        for (int i = 0; ; i++) {
            if (shackMan(i) == 45) {
                System.out.println("共有" + i + "人参加宴会");
                break;
            }
        }

4、一个青蛙向井口怕,井深10m,它每上升3m下降两米,问它需要爬几次能爬出井

    public static int frogClimb(int climbed, int time) {//climbed表示已爬,time表示当前是第几次爬
        if (climbed + 3 >= 10) {
            return time;
        } else {
            return frogClimb(time + 1, time + 1);
        }
    }

调用出传入0,1即可

 5、使用Linked实现先入先出的队列效果

    @org.junit.Test
    public void test(){
        LinkedList linkedList=new LinkedList();
        char[] chars={'a','c','d','s','s','e','f'};
        System.out.println("存储的顺序为:");
        for (char c:chars){
            System.out.print(c+" ");
            linkedList.addFirst(c);
        }
        System.out.println("\n取出的顺序为:");
        int size = linkedList.size();
        for (int i = 0; i <size ; i++) {
            System.out.print(linkedList.removeLast()+" ");
        }
    }

 

posted @ 2019-08-10 22:38  手握钢叉的猹  阅读(263)  评论(0编辑  收藏  举报