当前位置:   article > 正文

学点Java打小工_Day2Day3_一点作业

学点Java打小工_Day2Day3_一点作业

1 猜数字(10次机会)

随机生成[1,1000]的一个数,输入你猜的数程序会给出反馈,直到猜对或次数用尽(10次)。

    //猜数字 10次机会
    @Test
    public void guessNumber() {
        Random random = new Random();
        // [0, 1000) + 1
        // [1, 1000]
        int num = random.nextInt(1000) + 1;
        Scanner scanner = new Scanner(System.in);
        int cnt = 10;
        int num_guess;
        while (cnt > 0) {
            System.out.println("猜吧!请输入你猜的数字: ");
            num_guess = scanner.nextInt();
            System.out.println("你猜的数字是: " + num_guess);
            if (num_guess > num) {
                System.out.println("太大了");
                cnt--;
            } else if(num_guess < num) {
                System.out.println("太小了");
                cnt--;
            } else {
                System.out.println("恭喜你,猜对了");
                break;
            }
        }
        if (cnt == 0) {
            System.out.println("次数用尽,猜数失败");
        }
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29

2 打印99乘法表(双重循环)

双重for循环:
外层循环控制行数,数一下有几行就能确定外层循环。
内层循环控制列数,这一行打印多少个,到底要打印多少个要找出和当前行之间的一个关系。

    //打印99乘法表
    @Test
    public void print99Table() {
        for (int i = 1; i <= 9; i++) {
            for (int j = 1; j <= i; j++) {
                System.out.print(j + "×" + i + "=" + (i * j));
                if(j != i) {
                    System.out.print(" ");
                }
            }
            System.out.println();
        }
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

  做这个时候死去的上机题突然攻击我,控制了下每行最后一个空格不输出

3 判断闰年

  也有收获,之前写的时候逻辑有一点点混乱,这次搞清楚本身其实可以拆成两个条件:
    ①能被4整除但不能被100整除
    ②能被400整除
    有点数学容斥原理那味儿(死去的高中数学)

    @Test
    public void judgeLeapYear() {
        System.out.println("请输入你要查询的年份: ");
        Scanner scanner = new Scanner(System.in);
        int year_in = scanner.nextInt();
        if ((year_in % 4 == 0 && year_in % 100 != 0) || (year_in % 400 == 0)) {
            System.out.println(year_in + "年是闰年");
            return true;
        } else {
            System.out.println(year_in + "年不是闰年");
            return false;
        }
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

4 交换数字

    老生常谈了

    @Test
    public void exchangeNumber() {
        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入第一个数: ");
        int num1 = scanner.nextInt();
        System.out.println("请输入第二个数: ");
        int num2 = scanner.nextInt();
        System.out.println("交换前: num1 = " + num1 + "\t" + "num2 = " + num2);
        int temp = num1;
        num1 = num2;
        num2 = temp;
        System.out.println("交换后: num1 = " + num1 + "\t" + "num2 = " + num2);
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

    嗯,老师还提了一嘴可以有很多方法,我确实只知道这一种。随便一搜确实有很多种
    链接1
    链接2

5 收银台

编写一个收银台收款程序:
  定义输入----单价、数量、用户输入金额
  定义输出----应收金额、找零
  使用double类型变量 scanner.nextDouble();
  当总价>=500时候打八折
  考虑程序出现异常的情况,如:收款金额小于应收金额
  若收款金额大于等于应收金额,则计算找零后输出
  若收款金额小于应收金额,输出错误信息。

    这个我写得还挺“长”的,主要是有些信息执行完在控制台不显示,我又加了打印

    //收银台
    @Test
    public void recvMoney() {
        int cnt;
        double price, total, payment, change;
        Scanner scanner = new Scanner(System.in);

        System.out.print("请输入商品单价: ");
        price = scanner.nextDouble();
        System.out.println(price);

        System.out.print("请输入商品数量: ");
        cnt = scanner.nextInt();
        System.out.println(cnt);

        System.out.print("请付款: ");
        payment = scanner.nextDouble();
        System.out.println(payment);

        total = price * cnt;
        if (total >= 500) {
            System.out.println("商品总价超过500元, 给您打八折!");
            total *= 0.8;
        }
        if (payment < total) {
            System.out.println("对不起, 您的钱不够");
        } else {
            change = payment - total;
            System.out.println("找您" + String.format("%.2f", change));
        }
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31

6 打印直角三角形

输出以下结构:
1
12
123
1234
12345

    //输出直角三角形数
    @Test
    public void printRightTriangle() {
        for (int i = 1; i <= 5; i++) {
            for (int j = 1; j <= i; j++) {
                System.out.print(j);
            }
            System.out.println();
        }
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

7 打印正三角形/倒三角形

在这里插入图片描述在这里插入图片描述

    public void printEquilateralTriangle(int n) {
        int m;
        for (int i = 1; i <= n; i++) {
            for (int j = 1; j <= n - i; j++) {
                System.out.print(' ');
            }
            m = 2 * (i - 1) + 1;
            for (int j = 1; j <= m; j++) {
                System.out.print('*');
            }
            System.out.println();
        }
    }

    public void printInvertedTriangle(int n) {
        int m;
        for (int i = n; i >= 1; i--) {
            for (int j = 1; j <= n - i; j++) {
                System.out.print(' ');
            }
            m = 2 * (i - 1) + 1;
            for (int j = 1; j <= m; j++) {
                System.out.print('*');
            }
            System.out.println();
        }
    }

    //打印正三角/倒三角形
    @Test
    public void printTriangle() {
        Scanner scanner = new Scanner(System.in);
        System.out.print("请输入三角形阶数: ");
        int num = scanner.nextInt();
        System.out.println(num);

        System.out.print("请输入你要打印的三角形类型(1 正三角形; 2 倒三角形): ");
        int flag = scanner.nextInt();
        System.out.println(flag);

        int n = num;
        int m;

        if (flag == 1) {
            printEquilateralTriangle(n);
        } else if (flag == 2) {
            printInvertedTriangle(n);
        } else {
            System.out.println("非法输入 ");
        }
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51

  分开写了两个方法然后调用,这样比较舒服

8 求奇数偶数和

计算1-100以内所有奇数的和以及所有偶数的和,分别打印出来

    @Test
    public void printSum() {
        int sum_odd = 0;
        int sum_even = 0;
        for (int i = 1; i <= 100; i++) {
            if(i % 2 == 1) {
                sum_odd += i;
            }else {
                sum_even += i;
            }
        }
        System.out.println("sum_odd = " + sum_odd);
        System.out.println("sum_even = " + sum_even);
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

9 输出数字

用for循环输出1—1000之间能被5整除的数,且每行输出3个

    @Test
    public void printModFive() {
        int cnt = 0;
        for (int i = 1; i <= 1000; i++) {
            if(i % 5 == 0) {
                System.out.print(i);
                cnt++;
                if(cnt % 3 != 0) {
                    System.out.print(' ');
                }
                else {
                    cnt = 0;
                    System.out.println();
                }
            }
        }
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17

10 计算阶乘

计算9的阶乘

    @Test
    public void printFactorial() {
        int ans = 1;
        for(int i = 1; i <= 9; i++) {
            ans *= i;
        }
        System.out.println(ans);
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

  老师说还能用别的方法,我想到的是大数阶乘,那年暑假集训一道大数阶乘我做了一个晚自习。。。。
  大数阶乘1
  大数阶乘2
  其实他想说的是递归啦,那其实没啥本质区别了,能做的数还是有限的,不过确实算个进阶写法。
  后边再补吧,这周要叫开题报告、文献综述和外文翻译。想想就难受

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/270480
推荐阅读
相关标签
  

闽ICP备14008679号