2020.7.11(多重循环练习)

1、题目:判断2-100之间有多少个素数,并输出所有素数。
程序分析:判断素数的方法:用一个数分别去除2到 (这个数),如果能被整除,则表明此数不是素数,反之是素数。

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/10 22:41
 * @Description:
 **/
public class Test1 {
    public static void main(String[] args) {
        int count =0;
        boolean flag=true;
        System.out.print("2到100之间的素数是:");
        for (int i = 2; i <=100 ; i++) {
            for (int j = 2; j <i ; j++) {
                if(i%j==0){
                    flag=false;
                    break;
                }
            }
            if(flag){
                System.out.print(i+"\t");
                count++;
            }
        flag=true;
        }
        System.out.print("\n2-100之间有"+count+"个素数");
    }
}

2、 题目:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。例如:153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方。
程序分析:利用for循环控制100-999的数,每个数分解出个位,十位,百位。

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/10 23:36
 * @Description:打印出所有的"水仙花数"
 **/
public class Test2 {
    public static void main(String[] args) {
        int gewei;
        int shiwei;
        int baiwei;
        System.out.print("打印出所有的水仙花数:");
        for (int i = 100; i <=999 ; i++) {
            gewei=i%10;
            shiwei=i/10%10;
            baiwei=i/100%10;
            if(i==gewei*gewei*gewei+shiwei*shiwei*shiwei+baiwei*baiwei*baiwei){
                System.out.print(i+"\t");
            }
        }
    }
}

3、 题目:将一个正整数分解质因数。例如:输入90,打印出90=233*5。
程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:
(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。
(2)如果n不等于k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数n,重复执行第一步。
(3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。

import java.util.Scanner;

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/11 7:56
 * @Description:
 **/
public class Test3_03 {
    public static void main(String[] args) {
        Scanner sc=new Scanner(System.in);
        System.out.println("请输入一个正整数:");
        int num = sc.nextInt();
        System.out.print(num+"=");
        int k=2;//最小的质数为2
        boolean flag=false;//判断是否为分解的第一个质数
        do{
            if(num%k==0) {
                if(flag==false){
                    System.out.print(k);
                    num=num/k;
                    flag=true;
                }else{
                    num=num/k;
                    System.out.print("*"+k);
                }
            }else{
                k++;
            }
        }while (num!=1);
    }
}

4、 题目:求s=a+aa+aaa+aaaa+aa…a的值,其中a是一个数字。例如5+55+555+5555+55555(此时共有5个数相加)。
程序分析:关键是计算出每一项的值。。

import java.util.Scanner;

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/11 8:16
 * @Description:
 **/
public class Test4 {
    public static void main(String[] args) {
        System.out.println("请给定一个a的值:");
        Scanner sc=new Scanner(System.in);
        int a = sc.nextInt();
        //第2个数:55=5+5*10=5*(1+10)  第3个数:555=5+5*10+5*100=5*(1+10+100)
        //1+10+100+1000
        int num=1;//用来计算每一项的值
        int num1=1;
        int sum=0;
        //变量i控制累加的个数
        for (int i = 1; i <=a ; i++) {
            //(1+10+100+1000+...)
            for (int j = 1; j <i ; j++) {
                num1*=10;
                num+=num1;
            }
            sum=sum+num*a;
            num1=1;
            num=1;
        }
        System.out.println(sum);
    }
}

5、 题目:一个数如果恰好等于它的因子之和,这个数就称为"完数"。例如6=1+2+3.编程找出1000以内的所有完数

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/11 10:29
 * @Description:5、	题目:一个数如果恰好等于它的因子之和,这个数就称为"完数"。例
 * 如6=1+2+3.编程找出1000以内的所有完数
 **/
public class Test5 {
    public static void main(String[] args) {
        int wanshu=0;
        System.out.println("找到完数:");
        for (int i = 1; i <=1000 ; i++) {
            for (int j = 1; j <i ; j++) {
                if(i%j==0){
                    wanshu+=j;
                }
            }
            if(wanshu==i){
                System.out.println(wanshu+"\t");
            }
            wanshu=0;
        }
    }
}

6、 题目:一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在 第10次落地时,共经过多少米?第10次反弹多高

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/11 10:45
 * @Description:一球从100米高度自由落下,每次落地后反跳回原高度的一半;
 * 再落下,求它在 第10次落地时,共经过多少米?第10次反弹多高
 **/
public class Test6 {
    public static void main(String[] args) {
        double height=100;//高度,初始值是100
        int sum=100; //总共经过多少米,初始值为100
        for (int i = 2; i <=9 ; i++) {
                height*=0.5;
                sum+=height*2;
                //System.out.println("第"+i+"次落地时,共经过"+sum+"米,上一次反弹高度"+height+"米");
        }
        System.out.println("第10次落地时,共经过"+sum+"米,反弹高度"+height*0.5+"米");
    }
}

7、 题目:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?
程序分析:可填在百位、十位、个位的数字都是1、2、3、4。组成所有的排列后再去 掉不满足条件的排列。

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/11 11:05
 * @Description:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?
 **/
public class Test7 {
    public static void main(String[] args) {
        int num=0;
        int count=0;
        for (int i = 1; i <=4 ; i++) {
            for (int j = 1; j <=4 ; j++) {
                if(i==j){
                    continue;
                }
                for (int k = 1; k <=4 ; k++) {
                    if(k==i || k==j){
                        continue;
                    }
                    num=i*100+j*10+k;
                    System.out.print(num+"\t");
                    count++;
                }
            }
        }
        System.out.println("\n一共能组成"+count+"个互不相同且无重复数字的三位数");
    }
}

8、 题目:企业发放的奖金根据利润提成。利润(I)低于或等于10万元时,奖金可提10%;利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可可提成7.5%;20万到40万之间时,高于20万元的部分,可提成5%;40万到60万之间时高于40万元的部分,可提成3%;60万到100万之间时,高于60万元的部分,可提成1.5%,高于100万元时,超过100万元的部分按1%提成,从键盘输入当月利润I,求应发放奖金总数?
程序分析:请利用数轴来分界,定位。注意定义时需把奖金定义成长整型。

import java.util.Scanner;

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/11 11:39
 * @Description:
 **/
public class Test8 {
    public static void main(String[] args) {
        System.out.println("请输入当月利润:(单位:元)");
        Scanner sc=new Scanner(System.in);
        int money = sc.nextInt();
        long reward;
        if(money<=100000){
            reward=(long)(0.1*money);
        }else if(money<=200000){
            reward=(long)(100000*0.1+(money-100000)*0.075);
        }else if(money<=400000){
            reward=(long)(100000*0.1+100000*0.075+(money-200000)*0.05);
        }else if(money<=600000) {
            reward = (long) (100000 * 0.1 + 100000 * 0.075 +200000*0.05 +(money - 400000) * 0.03);
        }else if(money<=1000000){
            reward=(long)(100000*0.1+100000*0.075+200000*0.05+200000*0.03+(money-600000)*0.015);
        }else{
            reward=(long)(10*0.1+10*0.075+20*0.05+60*0.015+(money-100)*0.01);
        }
        System.out.println("应发放奖金总数"+reward+"元");
    }
}

9、 题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?
程序分析:在10万以内判断,另外由这个数的开方数自乘得到平方数,进行比较

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/11 13:26
 * @Description:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,
 * 请问该数是多少
 **/
public class Test9 {
    public static void main(String[] args) {
        int number;
        for (int i = 1; i <=100000 ; i++) {
            number=i*i-168-100;
            for (int j = 1; j <i ; j++) {
                if(j*j==(number+100)){
                    System.out.println(i+","+j+"这个整数是:"+number);
                }
            }
        }
    }
}

10、用*打印出菱形:在上午的三角形基础上打印
程序分析:先把图形分成两部分来看待,前四行一个规律,后三行一个规律,利用双重 for循环,第一层控制行,第二层控制列。

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/11 14:20
 * @Description:10、	用*打印出菱形
 **/
public class Test10 {
    public static void main(String[] args) {
        for (int i = 1; i <=4 ; i++) {
            for (int j = 1; j <5-i ; j++) {
                System.out.print(" ");
            }
            for (int j = 1; j <=2*i-1 ; j++) {
                System.out.print("*");
            }
            System.out.println();
        }
        for (int i = 1; i <=3 ; i++) {
            for (int j = 1; j <=i ; j++) {
                System.out.print(" ");
            }
            for (int j = 1; j <=7-2*i ; j++) {
                System.out.print("*");
            }
            System.out.println();
        }
    }
}

11、 有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13…求出这个数列的前20项之和。
程序分析:请抓住分子与分母的变化规律。

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/11 14:29
 * @Description:
 **/
public class Test11 {
    public static void main(String[] args) {
        double[] fenzi = new double[20];
        double[] fenmu = new double[20];
        double sum = 0;
        for (int i = 0; i < 20; i++) {
            if (i == 0) {
                fenzi[0] = 2;
                fenmu[0] = 1;
            } else if (i == 1) {
                fenzi[1] = 3;
                fenmu[1] = 2;
            } else {
                fenzi[i] = fenzi[i - 2] + fenzi[i - 1];
                fenmu[i] = fenmu[i - 2] + fenmu[i - 1];
            }
            sum += fenzi[i] / fenmu[i];
        }
        System.out.println(sum);
    }
}

12、 题目:给一个不多于5位的正整数,要求:一、求它是几位数,二、逆序打印出各位数字。

import java.util.Scanner;

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/11 15:03
 * @Description:
 **/
public class Test12 {
    public static void main(String[] args) {
        int count=0;
        int yushu;
        Scanner sc=new Scanner(System.in);
        System.out.println("请输入一个不多于5位的正整数:");
        int number = sc.nextInt();
        System.out.println("逆序打印出各位数字:");
        for (int i = 1; i <=5 ; i++) {
            if(number==0){
                break;
            }
            yushu=number%10;
            number=number/10;
            count++;
            System.out.print(yushu+"\t");
        }
        System.out.println("\n它是"+count+"位数");
    }
}

13、 一个5位数,判断它是不是回文数。即12321是回文数,个位与万位相同,十位与千位相同。

import java.util.Scanner;

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/11 15:31
 * @Description:
 **/
public class Test13 {
    public static void main(String[] args) {
/*        System.out.println("5位数的回文数有:");
        for (int i = 10000; i <=99999 ; i++) {
            if(i/10000==i%10 && i/1000%10==i/10%10){
                System.out.print(i+"\t");
            }
        }*/
        System.out.println("请输入一个5位数:");
        Scanner sc=new Scanner(System.in);
        int num = sc.nextInt();
        if(num/10000==num%10 && num/1000%10==num/10%10){
            System.out.println("这个数是回文数");
        }else{
            System.out.println("这个数不是回文数");
        }
    }
}

14、 题目:对10个数进行排序

import java.util.Scanner;

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/11 15:41
 * @Description:14、	题目:对10个数进行排序
 **/
public class Test14 {
    public static void main(String[] args) {
        Scanner sc=new Scanner(System.in);
        int num[]=new int[10];
        for (int i = 0; i <10 ; i++) {
            System.out.print("请输入第"+(i+1)+"个数:");
            num[i] = sc.nextInt();
            for (int j = 0; j <i ; j++) {
                if(num[i]<num[j]){
                    num[i]+=num[j];
                    num[j]=num[i]-num[j];
                    num[i]-=num[j];
                }
            }
        }
        System.out.print("由小到大排序为:");
        for (int i = 0; i <10 ; i++) {
            System.out.print(num[i]+" ");

        }
    }
}

15、 题目:打印出杨辉三角形(要求打印出10行如下图)
程序分析:
1
1 1
1 2 1
1 3 3 1
1 4 6 4 1
1 5 10 10 5 1

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/11 16:11
 * @Description:打印出杨辉三角形(要求打印出10行如下图)
 **/
public class Test15 {
    public static void main(String[] args) {
        //mark:小于这个数组长度会报错数组越界,最后一行无法打印:
        //Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException
        int num[][]=new int[11][11];
        for (int i = 1; i <=10 ; i++) {
            for (int j = 0; j <10-i ; j++) {
                System.out.print("  ");
            }
            for (int j = 1; j <=i ; j++) {
                if(j==1 || i==j){
                    num[i][j]=1;
                    System.out.print(num[i][j]+"  ");
                }else{
                    num[i][j]=num[i-1][j-1]+num[i-1][j];
                    System.out.print(num[i][j]+"  ");
                }
            }
            System.out.println();
        }
    }
}

16、 题目:求0—7所能组成的奇数个数。

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/11 17:02
 * @Description:16、	题目:求0—7所能组成的奇数个数。
 **/
public class Test16 {
    //结尾为1、3、5、7的就为奇数,应该是每个数只能用1遍
    //个位:4种可能  最高位:7-1种可能  其余位数:8-2 8-3 8-4
    public static void main(String[] args) {
        int num=0;
        int sum=0;
        for (int i = 1; i <=8 ; i++) {
            for (int j = 1; j <=i; j++) {
                if(j==1){
                    num=4;//个位
                }else if(j==2){
                    num=num*6;//最高位
                }else{
                    num=num*(8-j+1);
                }
            }
            System.out.println(i+"位数符合条件的有"+num+"个");
            sum+=num;
        }
        System.out.println("0—7所能组成的奇数个数是:"+sum);
    }

}

17、 打印直角三角形

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/11 18:37
 * @Description:17、	打印直角三角形 设定为5*5的
 **/
public class Test17 {
    public static void main(String[] args) {
        //直角边在左下
        for (int i = 0; i <5 ; i++) {
            for (int j = 0; j <=i; j++) {
                System.out.print("*");
            }
            System.out.println();
        }
        //直角边在左上
        for (int i = 0; i <5 ; i++) {
            for (int j = 0; j <5-i ; j++) {
                System.out.print("*");
            }
            System.out.println();
        }
        //直角边在右上
        for (int i = 0; i <5 ; i++) {
            for (int j = 0; j <i ; j++) {
                System.out.print(" ");
            }
            for (int j = 0; j <5-i ; j++) {
                System.out.print("*");
            }
            System.out.println();
        }
        //直角边在右下
        for (int i = 0; i <5 ; i++) {
            for (int j = 0; j <4-i ; j++) {
                System.out.print(" ");
            }
            for (int j = 0; j <=i ; j++) {
                System.out.print("*");
            }
            System.out.println();
        }

    }
}

18、 冒泡排序法
程序分析:01.外层循环N-1 (N:数的个数)
02.内层循环N-1-i (i:比较的轮数,外层循环的变量)
03.两两相比 小靠前!必须进行等量转换!互换位置!

import java.util.Scanner;

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/11 18:52
 * @Description:18、 冒泡排序法:比较两个相邻的元素,将值大的元素交换到右边
 * 程序分析:01.外层循环N-1   (N:数的个数)
 * 	02.内层循环N-1-i (i:比较的轮数,外层循环的变量)
 * 	03.两两相比 小靠前!必须进行等量转换!互换位置!
 **/
public class Test18 {
    public static void main(String[] args) {
        System.out.println("请输入多少个数进行排序:");
        Scanner sc=new Scanner(System.in);
        int N = sc.nextInt();
        int[] num=new int[N];
        for (int i = 0; i <=N-1 ; i++) {
            System.out.println("请输入第" + (i + 1) + "个数");
            num[i] = sc.nextInt();
        }
        for (int i = 0; i <=N-1 ; i++) {
            for (int j = 1; j <=N-1-i ; j++) {
                if(num[j-1]>num[j]){
                    num[j-1]+=num[j];
                    num[j]=num[j-1]-num[j];
                    num[j-1]=num[j-1]-num[j];
                }
            }
        }
        System.out.println("从小到大排序为:");
        for (int i = 0; i <=N-1 ; i++) {
            System.out.print(num[i]+" ");
        }
    }
}

19、 有3名顾客去商场购物,每人买3件商品…商品单价300元以上的商品享受8折优惠…请统计每人享受打折优惠的商品的数量

import java.util.Scanner;

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/11 19:34
 * @Description:19、	有3名顾客去商场购物,每人买3件商品
 * 商品单价300元以上的商品享受8折优惠
 * 请统计每人享受打折优惠的商品的数量
 **/
public class Test19{
    public static void main(String[] args) {
        Scanner sc=new Scanner(System.in);
        int price;
        int count=0;
        for (int i = 1; i <=3 ; i++) {
            for (int j = 1; j <=3 ; j++) {
                System.out.println("请输入第"+i+"名顾客购买的第"+j+"件商品的价格");
                price = sc.nextInt();
                if(price>300){
                    count++;
                }
            }
            System.out.println("第"+i+"名顾客享受打折的商品数量为"+count);
            count=0;
        }
    }
}

20、 打印梯形

/**
 * @Author: ChaoKeAiMuZhi
 * @Date: 2020/7/11 19:41
 * @Description:打印梯形 :参考一个三角形去掉前面几行
 **/
public class Test20 {
    public static void main(String[] args) {
        for (int i = 3; i <8; i++) {
            for (int j = 0; j <2*i-1 ; j++) {
                System.out.print("*");
            }
            System.out.println();
        }
    }

}

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值