Java初学记录

324 阅读2分钟

程序逻辑控制练习题 1.编写程序数一下 1到 100 的所有整数中出现多少个9 2.打印 1 - 100 之间所有的素数 3.猜数字游戏 4.计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值 5.求两个正整数的最大公约数 6.求一个整数,在内存当中存储时,二进制1的个数 7.获取一个数二进制序列中所有的偶数位和奇数位, 分别输出二进制序列 8.编写代码模拟三次密码输入的场景。 最多能输入三次密码,密码正确,提示“登录成功”,密码错误, 可以重新输 入,最多输入三次。三次均错,则提示退出程序 9.输出一个整数的每一位,如:123的每一位是1 , 2 , 3 1.编写程序数一下 1到 100 的所有整数中出现多少个9 思路:判断个位和十位上的数是否为9,是9则count++

public class Datatype { public static void main(String[] args) { int count = 0; for(int i=1;i<=100;i++){ if(i%10==9){ count++; } if(i/10==9){ count++; } } System.out.println(count); } } 1 2 3 4 5 6 7 8 9 10 11 12 13 14 运行结果:

2.打印 1 - 100 之间所有的素数 素数:质数又称素数。一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数叫做质数;否则称为合数(规定1既不是质数也不是合数)。

public class Datatype { public static void main(String[] args) { boolean flog; for(int i=2;i<=100;i++) { flog = true; for (int j = 2; j <i ; j++) { if (0==i % j ) { flog = false; } } if (flog == true) { System.out.print(i+" "); } } } }

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 运行结果:

3.猜数字游戏 完成猜数字游戏 ,用户输入数字,判断该数字是大于,小于,还是等于随机生成的数字(1~100)

import java.util.Random; import java.util.Scanner; public class Datatype { public static void main(String[] args) { Random rand = new Random(); int num = rand.nextInt(100)+1; Scanner sc = new Scanner(System.in); while(true){ System.out.print("请输入一个整形数据>"); int data = sc.nextInt(); if(data < num){ System.out.println("小了");

        }else if (data > num) {
            System.out.println("大了");

        }else {
            System.out.println("猜对了");
            break;
        }
    }
    sc.close();
}

} 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 运行结果:

4.计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值 public class Datatype { public static void main(String[] args) { double sum = 0; int j=1; for (int i = 1; i <= 100; i++) { sum=sum+(1.0/i)*j; j=-j; } System.out.println(sum); } }

运行结果:

5.求两个正整数的最大公约数 import java.util.Scanner; public class Datatype {public static void main(String[] args) { Scanner sc = new Scanner(System.in); System.out.print("请输入第一个整数"); int m = sc.nextInt(); System.out.print("请输入第二个整数"); int n = sc.nextInt(); main(m,n);

} public static void main(int m,int n){ if(m<n){ int temp = m; m = n; n = temp; } while(m % n != 0){ int temp = m % n; m = n; n = temp; } System.out.println(m+"和"+n+"的最大公约数为:"+n); } }

运行结果:

6.求一个整数,在内存当中存储时,二进制1的个数 思路: 1.使用按位与操作时会将十进制自动转化成二进制 2.将其与1相与,如果得到1表示该整数的最后一位为1; 3使用右移运算符>>,每次向右移一位可将该整数最右的一位不断去除,从而判断有几个1

import java.util.Scanner; public class Datatype { public static void main(String[] args) { Scanner sc = new Scanner(System.in); System.out.print("请输入一个整数"); int m = sc.nextInt(); int count = 0; for(int i = 0;i <32;i++) { if (((m >> i) & 1) == 1) { count++; }

    }
    System.out.printf("该整数的二进制一共有%d个1",count);
}

}

运行结果:

7.获取一个数二进制序列中所有的偶数位和奇数位, 分别输出二进制序列 import java.util.Scanner; public class Datatype { public static void main(String[] args) { Scanner sc = new Scanner(System.in); System.out.print("请输入一个整数"); int m = sc.nextInt(); int i = 0; System.out.println("偶数序列为:"); for(i = 31;i >= 1;i=i-2 ) { System.out.print((m>>i)&1); } System.out.println("\n奇数序列为:"); for(i = 30;i >= 0;i=i-2 ) { System.out.print((m>>i)&1); } }

运行结果:

8.编写代码模拟三次密码输入的场景。 最多能输入三次密码,密码正确,提示“登录成功”,密码错误, 可以重新输 入,最多输入三次。三次均错,则提示退出程序 import java.util.Scanner; public class Datatype { public static void main(String[] args){ System.out.println("欢迎使用"); for(int i=0;i<3;i++){ System.out.println("请输入6位密码:"); Scanner scan = new Scanner(System.in); String a = scan.next(); if(a.equals("257832")){ System.out.println("登陆成功"); break; } else{ System.out.println("密码错误,请重新输入,你还有"+(2-i)+"次输入机会"); } } } } 运行结果:

9.输出一个整数的每一位,如:123的每一位是1 , 2 , 3 import java.util.Scanner; public class Datatype { public static void main(String[] args){ Scanner scan = new Scanner(System.in); System.out.println("请输入一个三位整数:"); int a = scan.nextInt(); if(a>99 && a<1000){ System.out.println("百位为:"+(a/100)); System.out.println("十位为:"+(a/10)%10); System.out.println("个位为:"+(a%100)%10); } else{ System.out.println("输入错误,请重新输入!"); } } }

以上就是本次全部内容~~ ———————————————— 版权声明:本文为CSDN博主「Escapesisi」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。 原文链接:blog.csdn.net/Escapesisi/…