Java练习题

练习

1. (for 循环)计算1+2+3+...+100 的和

        int a = 0;
        for (int i = 1; i <= 100; i++) {
            a=a+i;
        }
        System.out.println(a);



2. (for 循环)计算1+3+5+...+99 的和
 

        int a =0;
        for (int i = 1; i <= 99; i++) {
            if (i%2==1){
                a=a+i;
            }
        }
        System.out.println(a);


3. (while/do…while 循环)把1、2 两题用while 循环或do...while 循环改



4. (for 循环)读入一个小于10 的整数n,输出它的阶乘n!


 

        Scanner sc = new Scanner(System.in);
        System.out.println("输入数");
        int a = sc.nextInt();
        sc.close();
        int c =1;
        if (a<=10) {

            for (int i = 1; i <= a; i++) {

               c=c*i;

            }
            System.out.println(c);
        }else {
            System.out.println("请输入10以内的数");
        }


5. (for 循环)求100 以内所有能被3 整除但不能被5 整除的数字的和。

        int a =0;
        for (int i = 0; i <= 100; i++) {
            if (i%3==0&&i%5!=0){
                System.out.println(i);
                a = a+i;
            }


        }
        System.out.println(a);



6. (for 循环)* “百钱买百鸡”是我国古代的著名数学题。题目这样描述:3 文

钱可以买1只公鸡,2 文钱可以买一只母鸡,1 文钱可以买3 只小鸡。用100 文

钱买100 只鸡,那么各有公鸡、母鸡、小鸡多少只?

        for (int i = 0; i<=33; i++) {
            for (int j = 0; j <=50; j++) {

                    if ((100 - i - j) % 3 == 0 && 3 * i + 2 * j + (100 - i - j) / 3 == 100)                {
                        System.out.print("公鸡"+i);
                        System.out.print("母鸡"+j);
                        System.out.print("小鸡"+(100-i-j));
                        System.out.println();


                }
            }

        }



7. (for 循环)*搬砖问题:36 块砖,36 人搬,男搬4,女搬3,两个小孩抬1 砖,

要求一次全搬完,问男、女和小孩各若干?

 

         for (int i = 0; i <= 9; i++) {
            for (int j = 0; j <=12 ; j++) {
                if ((36-i-j)%2==0&&4*i+3*j+(36-i-j)/2==36){
                    System.out.print("男"+i);
                    System.out.print("女"+j);
                    System.out.print("小孩"+(36-i-j));
                    System.out.println();
                }
            }
        }


8. (for 循环)*编程找出四位整数abcd 中满足下述关系的数。

(ab+cd)(ab+cd)=abcd

 

          for (int i = 1; i <=9; i++) {
            for (int j = 0; j <=9 ; j++) {
                for (int k = 0; k <=9 ; k++) {
                    for (int l = 0; l <=9 ; l++) {
                        if (((i*10+j)+(k*10+l))*((i*10+j)+(k*10+l))==i*1000+j*100+k*10+l){
                            System.out.println("i:" +i+"j:"+j+"k:"+k+"l:"+l);
                        }
                    }
                }
            }
        }


9. (循环)*读入一个整数n,输出如下图形

n = 3

*

***

*****

n = 4

*

***

*****

*******

思路:读入的整数n,就是外层循环的循环次数。

对于每一行,要做的事情:1. 输出若干个空格;2. 输出若干个星;3. 换行。

提示:输出不换行,用System.out.print()

        Scanner sc = new Scanner(System.in);
        System.out.println("输入几层");
        int a = sc.nextInt();
        for (int i = 0; i<=a; i++) {

            for (int j = 0; j < i; j++) {
                System.out.print("* ");
            }
            System.out.println();

            for (int j=a; j>i;j--) {
                System.out.print("-");
            }


        }



10. (循环)*输出99 乘法表
 

        Scanner sc = new Scanner(System.in);
        System.out.println("输入数");
        int a = sc.nextInt();
        sc.close();

        if (a<10) {

            for (int i = 1; i <= a; i++) {

                for (int j = 1; j <= i; j++) {
                    System.out.print(j+"*"+i+"="+(j*i)+"  ");

                }
                System.out.println("\n");

            }
        }else {
            System.out.println("请输入10以内的数");
        }


11. (循环)**求水仙花数。所谓水仙花数,是指一个三位数abc,如果满足

a3+b3+c3=abc,则abc 是水仙花数。

 

         for (int i = 0; i <= 9; i++) {
            for (int j = 0; j <=9; j++) {
                for (int k = 0; k <=9; k++) {
                    if ((i*i*i)+(j*j*j)+(k*k*k)==i*100+j*10+k){
                        System.out.println(i*100+j*10+k+"是水仙花数");
                    }
                }
            }
        }


12. (循环)**输入一个整数,计算它各位上数字的和。(注意:是任意位的整数)
 

        Scanner sc = new Scanner(System.in);
        System.out.println("输入整数");
        int a = sc.nextInt();

        int sum = 0;
        while (a !=0){
            sum += a%10;
            a /=10;
        }
        System.out.println(sum);


13. (循环)**输入一整数A,判断它是否质数。
提示1:若从2 到A 的平方根的范围内,没有一个数能整除A,则A 是质数。

        Scanner sc = new Scanner(System.in);
        System.out.println("输入数");
        int a = sc.nextInt();
        boolean b = true;


        for (int i = 2; i <= a-1; i++) {
            if (a%i==0){
                b = false;
                break;
            }
        }
        if (b){
            System.out.println("是质数");
        }else {
            System.out.println("不是质数");
        }




14. (循环)**如果一个数等于其所有因子之和,我们就称这个数为"完数",例如 6 的因子为1,2,3 6=1+2+3 6 就是一个完数.请编程打印出1000 以内所有的完数
 

          for (int i = 0; i < 1000; i++) {
            int sum =0;
            for (int j = 1; j < i / 2; j++) {
                if (i%j==0){
                    sum +=j;
                }
            }
            if (sum==i){
                System.out.println(sum);
            }
        }


16. (循环)**已知:faibonacci (费波那契)数列的前几个数分别为0,1,1,2,3,5,……。从第3 项开始,每一项都等于前两项的和。

读入一个整数n,编程求出此数列的前n 项。

注意:这里的数列是从0 开始的。

        Scanner sc = new Scanner(System.in);
        System.out.println("输入数");
        int n = sc.nextInt();

        System.out.println(allFai(n));
        sc.close();
    }
    //写一个递归函数,第 n 项的值
    public static int fai(int n){
        if(n == 1)
            return 0;
        if(n == 2)
            return 1;
        return fai(n - 1) + fai(n - 2);
    }
    //写一个递归函数,前 n 项的和
    public static int allFai(int n){
        if(n < 1)
            return -1;
        if(n == 1)
            return 0;
        if(n == 2)
            return 1;
        return allFai(fai(n--)) + allFai(fai(n - 1));
    }
}

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小乔同学Online

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值