大数据学习——关于多重循环的一些题目即解答

多重循环的题目

Text1 判断2-100之间有多少个素数,并输出所有素数。

程序分析:素数:只能被1和其本身整除;合数:除了1和其本身之外其他因数

public class Text1 {
    public static void main(String[] args) {
        //1、任意一个数如何判断其是不是质数/素数
        //2、一个是要从2-100循环,循环的每一个数执行上面的操作
        //3、如果有一个质数产生,计数器+1,同时打印该质数
        int count=0;
        for (int num = 2; num <=100; num++) {
            int flag=0;//判断是否是合数的标志
            for (int j = 2; j <num ; j++) {
                if(num%j==0){
                    //代表num是合数
                    flag=1;
                    break;
                }
            }if(flag!=0){
                //合数
            }else{
                //质数
                count++;
                System.out.println("质数:"+num);
            }
        }
        System.out.println("一共有"+count+"个质数");

        }
}

输出结果:
在这里插入图片描述

Text2 打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。例如:153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方。

程序分析:利用for循环控制100-999的数,每个数分解出个位,十位,百位。

public class Text2 {
    public static void main(String[] args) {
        //判断一个数是不是水仙花数:
       // 因为153=1的三次方+5的三次方+3的三次方
        //1、去除该三位数各位的数字
        //2、对这3个数字求立方
        //3、对立方的结果求和,与该数记性比较
        /*int num = 153;
        int a = num / 100;
        int b = num / 10 % 10;
        int c = num % 10;
        int d = a * a * a + b * b * b + c * c * c;
        if (num == d) {
            System.out.println(num + "是水仙花数");
        }*/   
        for (int i = 100; i < 1000; i++) {
            int a = i / 100%10;
            int b = i / 10 % 10;
            int c = i % 10;
                    if (i == a * a * a + b * b * b + c * c * c) {
                System.out.println(i+"是水仙花数");
            }
        }
    }
}

输出结果:
在这里插入图片描述

Text3 将一个正整数分解质因数。例如:输入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;
public class Text3 {
    public static void main(String[] args) {
        /*int num=90;
        System.out.print(num+"=");
        num/=2;
        System.out.print(2);
        num/=3;
        System.out.print("*"+3);
        num/=3;
        System.out.print("*" + 3);
        num/=5;
        System.out.print("*"+5);*/
       /* if (num == 1) {

        }*/
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入一个正整数:");
        int num = sc.nextInt();
        System.out.print(num + "=1");
        for (int i = 2; i <= num; i++) {
            if (i == num) {
                System.out.print("*" + num);
                break;
            } else {
                if (num % i == 0) {
                    num /= i;
                    System.out.print("*" + i);
                    i--;
                }
            }
        }
    }
}

输出结果:
在这里插入图片描述

Text4 求s=a+aa+aaa+aaaa+aa…a的值,其中a是一个数字。例如5+55+555+5555+55555(此时共有5个数相加)。

程序分析:关键是计算出每一项的值。

import java.util.Scanner;
public class Text4 {
    public static void main(String[] args) {
        Scanner sc=new Scanner(System.in);
        System.out.println("请输入一个10以内正整数:");
        int a=sc.nextInt();
        int sum=a;
        int num=a;
        for (int i = 2; i <=a ; i++) {
            num=num*10+a;
            sum+=num;
        } System.out.println(sum);
    }
}

输出结果:
在这里插入图片描述

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

public class Text5 {
    public static void main(String[] args) {
        for (int i = 2; i <=1000 ; i++) {
            //求某个数的所有因数
            int sum=0;//每次循环初始化一次和
            for (int j = 1; j <i ; j++) {
                if(i%j==0){
                    sum+=j;
                }
            }if(i==sum){
                System.out.println("完数"+i);
            }
        }
    }
}

输出结果:
在这里插入图片描述

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

public class Text6 {
    public static void main(String[] args) {
        double height = 100;
        double total=height;
        for (int i = 1; i <=10 ; i++) {
            height/=2;
            System.out.println("第" + i + "次反弹的高度为" + height);
            if(i==10){
                break;
            }total+=height*2;
        }
        System.out.println("第10次落地时,经过的路程为:"+total);
    }
}

输出结果:
在这里插入图片描述

Text7 有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?

程序分析:可填在百位、十位、个位的数字都是1、2、3、4。组成所有的排列后再去 掉不满足条件的排列。
下面展示一些 内联代码片

public class Text7 {
    public static void main(String[] args) {
        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;
                    System.out.println(i+""+j+k+"\t");
                    count++;
                }
            }
        }
    }
}

输出结果:
在这里插入图片描述

Text8 企业发放的奖金根据利润提成。利润(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,求应发放奖金总数?

程序分析:请利用数轴来分界,定位。注意定义时需把奖金定义成长整型。

public class Text8 {
    public static void main(String[] args) {
        Scanner sc=new Scanner(System.in);
        System.out.println("当月利润:");
        int money=sc.nextInt();
        double jiang=0;
        if(money<=100000){
            jiang=(long)(money*0.1);
        }else if(money<=200000){
            jiang=(long)(100000*0.1+(money-100000)*0.75);
        }else if(money<=400000){
            jiang=(long)(100000*0.1+100000*0.75+(money-200000)*0.05);
        }else if(money<=600000){
            jiang=(long)(100000*0.1+100000*0.75+200000*0.05+(money-400000)*0.03);
        }else if(money<=1000000){
            jiang=(long)(100000*0.1+100000*0.75+200000*0.05+200000*0.03+(money-600000)*0.015);
        }else{
            jiang=(long)(100000*0.1+100000*0.75+200000*0.05+200000*0.03+400000*0.015+(money-1000000)*0.01);
        }
        System.out.println(jiang);
    }
}

输出结果:
在这里插入图片描述

Text9 一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?

程序分析:在10万以内判断,另外由这个数的开方数自乘得到平方数,进行比较。

public class Text9 {
    public static void main(String[] args) {
        for (int i = 0; i <100000 ; i++) {
            //1、这个数加上100以后是完全平方数
            //2、这个数加上168以后是完全平方数
            int num1=i+100;
            int num2=i+268;
            boolean flag=false;
            int num=0;
            int tmp=0;
            for (int j = 1; j <400 ; j++) {
                if (num1==j*j){
                    tmp=j;
                    num=num1;
                    flag=true;
                }if(flag){
                    if(num2==j*j){
                        //System.out.println(i);
                        System.out.println(i + "+100=" + tmp * tmp);
                        System.out.println(i+"+268="+num2);
                    }
                }
            }
        }
    }
}

输出结果:
在这里插入图片描述

Text10 用*打印出菱形。在三角形基础上打印。

程序分析:先把图形分成两部分来看待,前几行一个规律,后几行一个规律,利用双重 for循环,第一层控制行,第二层控制列。

public class Text10 {
    public static void main(String[] args) {
        for (int i = 0; i <5; i++) {
            for (int j = 0; j <4-i ; j++) {
                System.out.print(" ");
            }
            for (int j = 0; j <2*i+1 ; j++) {
                System.out.print("*");
            }
            System.out.println();
        }
        for (int i = 0; i <4 ; i++) {
            for (int j = 0; j <=i ; j++) {
                System.out.print(" ");
            }
            for (int j = 0; j <7-2*i ; j++) {
                System.out.print("*");
            }
            System.out.println();
        }
    }
}

输出结果:
在这里插入图片描述

Text11 有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13…求出这个数列的前20项之和。

程序分析:请抓住分子与分母的变化规律。

public class Text11 {
    public static void main(String[] args) {
        int a=1;
        int b=2;double sum=b/(double)a;
        for (int i = 1; i <=20 ; i=i+2) {
            a = a + b;
            sum+=a/(double)b;
            b=a+b;
            sum+=b/(double)a;
        }
        System.out.println(sum);
    }
}

输出结果:
在这里插入图片描述

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

import java.util.Scanner;
public class Text12 {
    public static void main(String[] args) {
        Scanner sc=new Scanner(System.in);
        System.out.println("请输出一个不超过五位的正整数:");
        int num=sc.nextInt();
        int a=0;
        int b;
        for (int i = 1; i <=5 ; i++) {
            if(num==0){
                break;
            }
            b=num%10;
            num=num/10;
            a++;
            System.out.print(b+"\t");
        }
        System.out.println("这个数是"+a+"位数。");
    }
}

输出结果:
在这里插入图片描述

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

import java.util.Scanner;
public class Text13 {
    public static void main(String[] args) {
        Scanner sc=new Scanner(System.in);
        System.out.println("请输入一个五位数:");
        int num=sc.nextInt();
        if(num%10==num/10000 && num/10%10==num/1000%10){
            System.out.println("这个数是回文数。");
        }else{
            System.out.println("这个数不是回文数。");
        }
    }
}

输出结果:
在这里插入图片描述

Text14 对10个数进行排序

//import java.util.Scanner;
public class Text14 {
    public static void main(String[] args) {
       /* Scanner sc=new Scanner(System.in);
        System.out.println("请输入十个数:");
        int num=sc.nextInt();*/
        int[] arr = {1,4,3,6,7,5,8,10,9,2};
        for (int i = 0; i < arr.length; i++) {
        for(int j = i + 1; j < arr.length; j++) {
            if(arr[i] >= arr[j]) {
                int n = arr[i];
                arr[i] = arr[j];
                arr[j] = n;
            }
        }
         System.out.print(arr[i] + " ");
    }
}
}

输出结果:
在这里插入图片描述

Text15 打印出杨辉三角形。

杨辉三角形(是二项式系数在三角形中的一种几何排列,它把二项式系数图形化,把组合数内在的一些代数性质直观地从图形中体现出来,是一种离散型的数与形的结合)
在这里插入图片描述

public class Text15 {
    public static void main(String[] args) {
        int num=5;
        for (int i = 0; i <num ; i++) {
            int v=1;
            int a=i;
            for (int j = 0; j <=i ; j++) {

//                int b=j;
                if(j==0) System.out.print(1+" ");
                else{
                    System.out.print((v=v/j)+" ");
                }
                v *= a;
                a--;
//                b++;
            }
            System.out.println();
        }
    }
}

输出结果:
在这里插入图片描述

Text16 求0—7所能组成的奇数个数。

public class Text16 {
    public static void main(String[] args) {
     int num=8;
             int count=0;
                count+=num/2;//一位数的奇数
                count+=(num-1)*num/2;//二位数的奇数
        count+=(num-1)*num*num/2;//三位数的奇数
        count+=(num-1)*num*num*num/2;//四位数的奇数
        count+=(num-1)*num*num*num*num/2;//五位数的奇数
        count+=(num-1)*num*num*num*num*num/2;//六位数的奇数
        count+=(num-1)*num*num*num*num*num*num/1;//七位数的奇数
        System.out.println("0-7一共可以组成"+count+"个奇数。");
    }
}

输出结果:
在这里插入图片描述

Text17 打印直角三角形。

public class Text17 {
    public static void main(String[] args) {
        //直角在左下的直角三角形
       /* for (int i = 1; i <=9 ; i++) {
            for (int j = 1; j <=i ; j++) {
                System.out.print("*");
            }
            System.out.println(" ");
        }
        System.out.println();*/
       //直角在左上的直角三角形
     /*  for (int i = 1; i <=9 ; i++) {
            for (int j = 1; j <9-i ; j++) {
                System.out.print("*");
            }
            System.out.println();
        }*/
     //直角在右下的直角三角形
      /*  for (int i = 1; i <9; i++) {
            for (int j = 1; j <9-i ; j++) {
                System.out.print(" ");
            }
            for (int j = 1; j <=i ; j++) {
                System.out.print("*");
            }
            System.out.println();
        }*/
      //直角在右上的直角三角形
        for (int i = 1; i <9 ; i++) {
            for (int j = 1; j <=i-1 ; j++) {
                System.out.print(" ");
            }
            for (int j = 1; j <9-i ; j++) {
                System.out.print("*");
            }
            System.out.println();
        }
}
}

输出结果:
在这里插入图片描述

Text18 打印梯形。

public class Text20 {
    public static void main(String[] args) {
        for (int i = 3; i <=9 ; i++) {
            for (int j = 1; j <=i ; j++) {
                System.out.print("*");
            }
            System.out.println(" ");
        }
        System.out.println();
    }
}

输出结果:
在这里插入图片描述

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值