Java程序逻辑控制,刷完这些你就懂了

目录

  • 判断年龄段
  • 判断素数
  • 打印闰年
  • 乘法口诀表
  • 最大公约数
  • 计算分数
  • 数9
  • 水仙花数
  • 模拟登陆
  • 二进制中的1
  • 奇偶二进制
  • 输出一个整数的每一位
  • 猜数字游戏

判断年龄段

题目:根据年龄, 来打印出当前年龄的人是少年(低于18), 青年(19-28), 中年(29-55), 老年(56以上)。
注:不要一看到多分支就想到switch,switch不支持复杂的表达式,例如题目中的范围表达式。switch中可以是整数(int)、枚举、字符和字符串

import java.util.Scanner;

public class JudgeAge {
     
    public static void main(String[] args) {
     
        Scanner scan = new Scanner(System.in);
        int age = scan.nextInt();
        if (age <= 18){
     
            System.out.println("少年");
        }else if(age > 18 && age <= 28){
     
            System.out.println("青年");
        }else if(age > 29 && age <= 55){
     
            System.out.println("中年");
        }else {
     
            System.out.println("老年");
        }
    }
}

判断素数

题目:判定一个数字是否是素数
在这里先渗透一下“方法”

import java.util.Scanner;

public class PrimeNumber {
     
    public static void main(String[] args) {
     
        Scanner scan = new Scanner(System.in);
        int num = scan.nextInt();
        if(IsPrimeNum(num)){
     
            System.out.println(num+"是素数");
        }else {
     
            System.out.println(num+"不是素数");
        }
    }

    public static boolean IsPrimeNum(int x){
     
        if (x < 2){
     
            return false;
        }
        for (int i = 2; i <= Math.sqrt(x); i++) {
     
            if (x % i == 0){
     
                return false;
            }
        }
        return true;
    }
}

打印闰年

题目:输出1000 ~ 2000之间所有的闰年

public class PriLeapYears {
     
    public static void main(String[] args) {
     
        for (int i = 1000; i <= 2000; i++) {
     
            if (i % 4 == 0 && i % 100 != 0 || i % 400 == 0){
     
                System.out.println(i);
            }
        }
    }
}

乘法口诀表

题目:打印乘法口诀表

import java.util.Scanner;

public class Mul {
     
    public static void main(String[] args) {
     
        Scanner scan = new Scanner(System.in);
        int n = scan.nextInt();
        for (int i = 1; i <= n ; i++) {
     
            for (int j = 1; j <= i ; j++) {
     
                System.out.printf("%d*%d=%d ",j,i,j*i);
            }
            System.out.println();
        }
    }
}

最大公约数

题目:求两个正整数的最大公约数
求最大公约数的时候,我们采用的是辗转相除法。有人可能会有疑问,难道不需要判断两个数的大小吗?答案是不需要,即使是前小后大,也会互换过来,去试试吧!

import java.util.Scanner;

public class CommonDivisor {
     
    public static void main(String[] args) {
     
        Scanner scan = new Scanner(System.in);
        int a = scan.nextInt();
        int b = scan.nextInt();
        int c = 0;
        while(a % b != 0){
     
            c = a % b;
            a = b;
            b = c;
        }
        System.out.println("最大公约数位:" + b);
    }
}

计算分数

题目:计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值。
计算分数首先要注意是double型,其次是要注意正负交替!

public class Fraction {
     
    public static void main(String[] args) {
     
        double result = 0.0;
        double i,n = 1;
        for (i = 1; i <= 100; i++) {
     
            result += n/i;
            n = -n;
        }
        System.out.println("result = " + result);
    }
}

数9

题目:编写程序数一下 1到 100 的所有整数中出现多少个数字9。

public class Num9 {
     
    public static void main(String[] args) {
     
        int num = 0;
        for (int i = 1; i <= 100; i++) {
     
            if(i % 10 == 9){
     
                num++;
            }
            if (i / 10 == 9){
     
                num++;
            }
        }
        System.out.println("1~100数字9的个数是:"+ num);
    }
}

水仙花数

题目:求出0~999之间的所有“水仙花数”并输出。(“水仙花数”是指一个三位数,其各位数字的立方和确好等于该数本 身,如;153=111+555+333,则153是一个“水仙花数”。)

public class NarcissusNum {
     
    public static void main(String[] args) {
     
        int num = 100;
        while(num < 1000){
     
            if(num == (num/100)*(num/100)*(num/100)
                    + ((num % 100)/10)*((num % 100)/10)*((num % 100)/10)
                    + (num % 10)*(num % 10)*(num % 10)){
     
                System.out.println(num);
            }
            num++;
        }
    }
}

模拟登陆

题目:编写代码模拟三次密码输入的场景。 最多能输入三次密码,密码正确,提示“登录成功”,密码错误, 可以重新输 入,最多输入三次。三次均错,则提示退出程序
Java中的字符串比较,需要用equals

import java.util.Scanner;

public class UsersLogin {
     
    public static void main(String[] args) {
     
        Scanner scan = new Scanner(System.in);
        System.out.println("用户登录界面");
        for (int i = 0; i < 3; i++) {
     
            System.out.println("请输入您的用户名:");
            String userName = scan.next();
            System.out.println("请输入您的密码");
            String password = scan.next();
            if (userName.equals("Aisen") && password.equals("FeiFei")){
     
                System.out.println("登陆成功");
                break;
            }else {
     
                System.out.println("密码错误,请重新输入!您还有" + (3-i-1) +"次机会!");
            }
        }
    }
}

二进制中的1

题目:写一个函数返回参数二进制中 1 的个数 比如: 15 0000 1111 4 个1
方法1:数字右移,然后和1进行按位与操作

import java.util.Scanner;

public class BinaryNum1 {
     
    public static void main(String[] args) {
     
        Scanner scan = new Scanner(System.in);
        int num = scan.nextInt();
        int count = 0;
        while(num != 0){
     
            if((num & 1) == 1){
     
                count++;
            }
            num >>>= 1;
        }
        System.out.println(num + "的二进制序列中1的个数为:" + count);
    }
}

方法2:
Java程序逻辑控制,刷完这些你就懂了_第1张图片

import java.util.Scanner;

public class BinaryNum1 {
     
    public static void main(String[] args) {
     
        Scanner scan = new Scanner(System.in);
        int num = scan.nextInt();
        int count = 0;
        while(num != 0){
     
            count++;
            num &= num - 1;
        }
        System.out.println(num + "的二进制序列中1的个数为:" + count);
    }
}

奇偶二进制

题目:获取一个数二进制序列中所有的偶数位和奇数位, 分别输出二进制序列

import java.util.Scanner;

public class OddEven {
     
    public static void main(String[] args) {
     
        Scanner scan = new Scanner(System.in);
        int num =scan.nextInt();
        System.out.println("偶数序列:");
        for (int i = 31; i > 0; i -= 2) {
     
            System.out.print((num >> i) & 1);
        }
        System.out.println();
        System.out.println("奇数序列:");
        for (int i = 30; i >= 0; i -= 2) {
     
            System.out.print((num >> i) & 1);
        }
    }
}

输出一个整数的每一位

题目:输出一个整数的每一位.
正常的取每一位会利用循环先%10,再/10。可是如果是这样的话就会反向输出,所以我们就可以用一下递归~

import java.util.Scanner;

public class PriNum {
     
    public static void main(String[] args) {
     
        Scanner scan = new Scanner(System.in);
        int num = scan.nextInt();
        PriNums(num);
    }
    public static void PriNums(int num){
     
        if (num < 10){
     
            System.out.print(num);
        }else {
     
            PriNums(num/10);
            System.out.printf(", " + (num % 10));
        }
    }
}

猜数字游戏

题目:完成猜数字游戏
所谓猜数字,那正确答案肯定最好是随机的,所以这时候我们就需要利用一个方法Random,但是切记Java中的范围是左闭右开的。

import java.util.Random;
import java.util.Scanner;

public class GuessNum {
     
    public static void main(String[] args) {
     
        Scanner scan = new Scanner(System.in);
        Random rand = new Random();
        int randNum = rand.nextInt(100);//随机数,左闭右开,范围是1~99
        while(true){
     
            int guessNum = scan.nextInt();//用户猜测的数字
            if(guessNum == randNum){
     
                System.out.println("恭喜你猜对了!");
                break;
            }else if (guessNum < randNum){
     
                System.out.println("猜小了");
            }else {
     
                System.out.println("猜大了");
            }
        }
    }
}

你可能感兴趣的:(Java,java,switch,字符串,经验分享)