Java基础编程1-18题

【1】有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?

public class lianxi01{
    public static void main(String[] args){
        Scanner input = new Scanner(System.in);
	System.out.print("请输入要计算的月数:");
	int m = input.newxtInt();
	int i = 1;
	int[] arr = new int[m+1];
	for(i=1; i<m+1; i++){
	    if(i==1 | i==2){
	        arr[1]=arr[2]=1;
	    }else{
	        arr[i]=arr[i-2]+arr[i-1];
	    }
	    for(i=1; i<=m; i++){
	        System.out.println("第" + i + "个月的兔子数目为:" + arr[i]);
	    }
	}
    }
}
【2】判断101-200之间有多少个素数,并输出所有素数。
程序分析:判断素数的方法:用一个输分别去除2到sqrt(这个数),如果能被整除,则表明次数不是素数,反之是素数。
public class lianxi02{
    public static void main(String[] args){
        int count = 0;
	for(int i = 101; i<200; i+=2){
	    boolean b = false;
	    for(int j=2; j<=Math.sqrt(i); i++){
	        if(i % j ==0){
		    b = false;
		    break;
		}else{
		    b = true;
		}
		if(b == true){
		    count ++;
		    System.out.println(i)
		}
		System.out.println("素数的个数是:" + count);
	    }
	}
    }
}

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

public class lianxi03{
    public static void main(String[] args){
        int b1,b2,b3;
	for(int m=101; m<1000; m++){
	    b3 = m / 100;
	    b2 = m % 100 / 10;
	    b1 = m % 10;
	    if((b3*b3*b3 + b2*b2*b2 + b1*b1*b1) == m){
	        System.out.println(m + "是一个水仙花数");
	    }
	}
    }
}
【4】将一个正整数分解质因数。例如:输入90,打印出90 = 2*3*3*5.
程序分析;对n进行分解质因数,应先找到一个最小的质数K,然后按下述步骤完成:
《1》如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可;
《2》如果n < > k,但 n 能被 k 整除,则应打印出 k 的值,并用 n 除以 k 的商,作为新的正整数n,重复执行第一步;
《3》如果n不能被k整除,则用k+1作为k的值,重复执行第一步。
public class lianxi04{
    public static void main(String[] args){
        Scanner s = new Scanner(System.in);
	int n = s.nextInt();
	int k = 2;
	System.out.print(n + "=");
	while(k <= n){
	    if(k == n){
	        System.out.println(n); 
		break; 
	    }else if(n % k == 0){
	        System.out.print(k + "*");
		n = n / k;
	    }else{
	        k++;
	    }
	}
    }
}
【5】利用条件运算符的嵌套来完成此题:学习成绩 >= 90分的同学用A表示,60-89分之间的用B表示,60分以下的用C表示。
public class lianxi05{
    public static void main(String[] args){
	char grade;
	Scanner s = new Scanner(System.in);
	System.out.print("请输入一个成绩:");
	int x = s.nextInt();
	grade = x >= 90 ? 'A' 
		: >= 60 ? "B" 
		: 'C';
	System.out.println("等级为:" + grade);
    }
}
【6】输入两个正整数m和n,求其最大公约数和最小公倍数。
/**
  *在循环中,只要除数不等于0,用较大数除以较小的数,将小的一个数作为下一轮循环的大数,取得的余数作为下一轮循环的较小
  *的数,如此循环直到较小的数的值为0,返回较大的数,次数即为最大公约数,最小公倍数为两数之积除以最大公约数
  */
<pre name="code" class="java">public class lianxi06 {
    public static void main(String[] args){
        int a,b,m;
        Scanner s = new Scanner(System.in);
        System.out.println("请输入一个正整数:");
        a = s.nextInt();
        System.out.println("请再输入一个正整数:");
        b = s.nextInt();
        deff cd = new deff();
        m = cd.deff(a,b);
        int n = a*b / m;
        System.out.println("最大公约数为:" + m);
        System.out.println("最小公倍数为:" + n);
    }
}
class deff{
    public int deff(int x,int y){
        int t;
        if(x < y){
            t = x;
            x = y;
            y = t;
        }
        while(y != 0){
            if(x == y){
                return x;
            }else{
                int k = x % y;
                x = y;
                y = k;
            }
        }
        return x;
    }
}

 【7】输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。 
public class lianxi07{
    public static void main(String[] args){
        int digital = 0;
	int character = 0;
	int other = 0;
	int blank = 0;
	char[] ch = null;
	Scanner sc = new Scanner(System.in);
	String s = sc.nextLine();
	ch = s.toCharArray();
	for(int i=0; i<ch.length; i++){
	    if(ch >= '0' && ch <= '9'){ 
	        digital++; 
	    }else if( (ch >= 'a' && ch <= 'z') || (ch >'A' && ch <='Z') ){
	        character++;
	    }else if(ch == ' '){
	        blank++;
	    }else{
	        other++;
	    }
	}
	System.out.println("数字个数:" + digital);
	System.out.println("英文字母个数:" + character);
	System.out.println("空格个数:" + blank);
	System.out.println("其它字符个数:" + other);
    }
}
【8】求s=a+aa+aaa+aaaa+aa...a的值,其中a是一个数字。例如:2+22+222+2222+22222(此时共有5个数相加),几个数相加由键盘控制。
publi class lianxi08{
    public static void main(String[] args){
        long a, b=0, sum=0;
	Scanner s = new Scanner(System.in);
	System.out.print("输入数字a的值:");
	a = s.nextInt();
	System.out.print("输入相加的项数:");
	int n = s.nextInt();
	int i = 0;
	while(i < n){
	    b = b + a;
	    sum = sum + b;
	    a = a*10;
	    ++i;
	}
	System.out.println(sum);
    }
}
【9】一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如:6=1+2+3.求找出1000以内的所有完数。
public class lianxi09{
    public static void main(String[] args){
         System.out.println("1到1000之间的完数有:");
	 for(int i=1; i<1000; i++){
	     int t=0;
	     for(int j=1; j<=i/2; j++){
	         if(i%j==0){
		     t=t+j;
		 }
	     }
	     if(t==i){
	         System.out.print(i + " ");     
	     }
	 }
    }
}
【10】一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第10次落地时,共经过多少米?第10次反弹多高?
public class lianxi10{
    public static void main(String[] args){
        double h=100, s=100;
	for(int i=1; i<10; i++){
	    s = s+h;
	    h = h/2;
	}
	System.out.println("经过路程:" + s);
	System.out.println("反弹高度:" + h/2);
    }
}

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

public class lianxi11{
    public static void main(String[] args){
        int count = 0;
	for(int x=1; x<5; x++){
	    for(int y=1; y<5; y++){
	        for(int z=1; z<5; z++){
		    if(x!=y && y!=z && x!=z){
		        count++;
			System.out.println(x*100 + y*10 + z);
		    }
		}
	    }
	}
	System.out.println("共有" + count + "个三位数");
    }
}
【12】企业发放的奖金根据利润提成。利润(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%提成。
           从键盘输入当月利润,求应发放奖金总数?
public class lianxi12{
    public static void main(String[] args){
        double x=0, y=0;
	System.out.print("输入当月利润(万):");
	Scanner s = new Scanner(System.in);
	x = s.nextInt();
	if(x>0 && x<=10){
	    y = x*0.1;
	}else if(x>10 && x<=20){
	    y = 10*0.1 + (x-10)*0.075;
	}else if(x>20 && x<=40){
	    y = 10*0.1 + 10*0.075 + (x-20)*0.05;
	}else if(x>40 && x<=60){
	    y = 10*0.1 + 10*0.075 + 20*0.05 + (x-40)*0.03;
	}else if(x>60 && x<=100){
	    y = 10*0.1 + 10*0.075 + 20*0.05 + 20*0.03 + (x-60)*0.015;
	}else if(x>100){
	    y = 10*0.1 + 10*0.075 + 20*0.05 + 20*0.03 + 40*0.015 + (x-100)*0.01;
	}
	System.out.println("应该提取的奖金是:" + y + "万");
    }
}
【13】有一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?
public class lianxi13{
    public static void main(String[] args){
        for(int x=-100; x<10000; x++){
	    if(Math.sqrt(x+100)%1 == 0){
	        if(Math.sqrt(x+268)%1 == 0){
		    System.out.println(x + "加100后是一个平方数,再加168后又是另一个完全平方数");
		}
	    }
	}
    }
}
/**
  *按题意循环应该从-100开始(整数包括正整数、负整数、零),这样就会多一个满足条件的数:-99.
  */
【14】输入某年某月某日,判断这一天是这一年的第几天?
public class lianxi14{
    public static void main(String[] args){
        int year,month,day;
	int days=0;
	int d=0;
	int e;
	input fymd = new input();
	do{
	    e = 0;
	    System.out.print("请输入年:");
	    year = fymd.input();
	    System.out.print("请输入月:");
	    month = fymd.input();
	    System.out.print("请输入天:");
	    day = fymd.input();
	    if(year<0 || month<0 || month>12 || day<0 || day>31){
	        System.out.println("输入错误,请重新输入!");
		e=1;
	    }
	}while(e==1);
	for(int i=1; i<month; i++){
	    switch(i){
	        case 1:
		case 3:
		case 5:
		case 7:
		case 8:
		case 10:
		case 12: days=31; break;
		case 4:
		case 6:
		case 9:
		case 11: days=30; break; 
		case 2:
		if((year%400==0) || (year%4==0 && year%100 != 0)){
		    days=29;
		}else{
		    days=28;
		} 
		break;
	    }
	    d += days;
	}
	System.out.println(year + "-" + month + "-" + day + "是这年的第" + (d+day) + "天!");
    }
}
class input{
    public int input(){
        int value = 0;
	Scanner s = new Scanner(System.in);
	value = s.nextInt();
	return value;
    }
}
【15】输入三个整数x,y,z,请把这三个数由小到大输出。
public class lianxi15{
    public static void main(String[] args){
        input fnc = new input();
	int x=0,y=0,z=0;
	System.out.print("请输入第一个数字:");
	x = fnc.input();
	System.out.print("请输入第二个数字:");
	y = fnc.input();
	System.out.print("请输入第三个数字:");
	z = fnc.input();
	if(x>y){
	    int t=x;
	    x=y;
	    y=t;
	}
	if(x>z){
	    int t=x;
	    x=z;
	    z=t;
	}
	if(y>z){
	    int t=y;
	    y=z;
	    z=t;
	}
	System.out.println("三个数字由小到大排列为:" + x + " " + y + " " + z);
    }
}
class input{
    public int input(){
        int value=0;
	Scanner s = new Scanner(System.in);
	value = s.nextInt();
	return value;
    }
}
【16】输出9*9乘法表
public class lianxi16{
    public static void main(String[] args){
        for(int i=1; i<10; i++){
	    for(int j=1; j<=i; j++){
	        System.out.print(j + "*" + i + "=" + j*i + "    ");
		if(j*i<10){
		    System.out.print(" ");
		}
	    }
	    System.out.println();
	}
    }
}
【17】猴子吃桃问题。猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个。
第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下的一半零一个。
到第十天早上在想吃时,就只剩一个桃子了。求第一天共摘了多少个桃子?
public class lianxi17{
    public static void main(String[] args){
        int x=1;
	for(int i=2; i<=10; i++){
	    x=(x+1)*2;
	}
	System.out.println("猴子第一天摘了" + "个桃子");
    }
}
【18】两个乒乓球队进行比赛,各出三人。甲队为a,b,c三人,乙队为x,y,z三人。已抽签决定比赛名单。
有人向队员打听比赛的名单。a说他不和x比,c说他不和x,z比,请编程序找出三队赛手的名单。
public class lianxi18{
    public static void main(String[] args){
        char i,j,k;                                           //  假设i是a的对手,j是b的对手,k是c的对手
        for(i='x';i<='z';i++){                                //  穷举法
            if(i!='x'){                                       //  A的对手不是x
                for(k='x';k<='z';k++){
                    if(k!='x'&&k!='z'){                       //  C的对手不是x,z
                        for(j='x';j<='z';j++){
                            if(i!=j&&i!=k&&j!=k){             //  排除三人对手相同的情况
                                System.out.println("a--" + i);
                                System.out.println("b--" + j);
                                System.out.println("c--" + k);
                            }
                        }
                    }
                }
            }
        }
    }
}










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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值