竞赛java编程题50题(有答案).pdf

上传人:l**** 文档编号:72370387 上传时间:2023-02-10 格式:PDF 页数:60 大小:1.22MB
返回 下载 相关 举报
竞赛java编程题50题(有答案).pdf_第1页
第1页 / 共60页
竞赛java编程题50题(有答案).pdf_第2页
第2页 / 共60页
点击查看更多>>
资源描述

《竞赛java编程题50题(有答案).pdf》由会员分享,可在线阅读,更多相关《竞赛java编程题50题(有答案).pdf(60页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、【程序 1】题目:古典问题:有一对兔子,从出生后第 3 个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?/这是一个菲波拉契数列问题public class lianxi01 public static void main(String args)System.out.println(第 1 个月的兔子对数:1);System.out.println(第 2 个月的兔子对数:1);int f1=1,f2=1,f,M=24;for(int i=3;i=M;i+)f=f2;f2=f1+f2;f1=f;System.out.println(第

2、+i+个月的兔子对数:+f2);packagepackage akjava;publicpublic classclass tuzi/*paramparam args*/publicpublic staticstatic voidvoid main(String args)intint f1=1,f2=1,f;System.out.println(第1个月的兔子对数:1System.out.println(第2个月的兔子对数:1forfor(intint i=3;i23;i+)f=f1+f2;););f1=f2;f2=f;System.out.println(第+i+月是:t+f+只兔子!);

3、【程序 2】题目:判断 101-200 之间有多少个素数,并输出所有素数。程序分析:判断素数的方法:用一个数分别去除2 到 sqrt(这个数),如果能被整除,此数不是素数,反之是素数。则表明public class lianxi02 public static void main(String args)int count=0;for(int i=101;i200;i+=2)boolean b=false;for(int j=2;j=Math.sqrt(i);j+)if(i%j=0)b=false;break;else b=true;if(b=true)count+;System.out.pr

4、intln(i);System.out.println(素数个数是:+count);packagepackage akjava;publicpublic classclass Sushu/*paramparam args*/publicpublic staticstatic voidvoid main(String args)intint j,num=0;System.out.println(101 200的素数是:);forfor(intint i=101;i200;i+)forfor(j=2;ji;j+)ifif(i%j=0)breakbreak;if(i=j)System.out.pri

5、nt(+i);num+;System.out.print(n素数的个数是:+num);【程序 3】题目:打印出所有的 水仙花数,所谓 水仙花数 是指一个三位数,其各位数字立方和等于该数本身。例如:153 是一个 水仙花数,因为 153=1 的三次方5 的三次方3 的三次方。public class lianxi03 public static void main(String args)int b1,b2,b3;for(int m=101;m1000;m+)b3=m/100;b2=m%100/10;b1=m%10;if(b3*b3*b3+b2*b2*b2+b1*b1*b1)=m)System.

6、out.println(m+是一个水仙花数);packagepackage akjava;publicpublic classclass ShuiXianHua/*paramparam args*/publicpublic staticstatic voidvoid main(String args)System.out.println(符合水仙花数的三位数是:);intint a=0,b=0,c=0;forfor(intint i=100;i0;)a=j%10;j=j/10;b=j%10;j=j/10;c=j%10;j=j/10;ifif(i=Math.pow(a,3)+Math.pow(b

7、,3)+Math.pow(c,3)System.out.print(+i);【程序 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 的值,重复执行第一步。import java.util.*;publicclasslianxi

8、04public static void main(String args)Scanner s=new Scanner(System.in);System.out.print(请键入一个正整数:);intn=s.nextInt();int k=2;System.out.print(n+=);while(k 1;)/if(n=k)System.out.println(n+=+n+*1);break;/elseifif(n%k=0)System.out.print(k);n=n/k;ifif(n!=1)System.out.print(*);k+;elsek+;【程序 5】题目:利用条件运算符的嵌

9、套来完成此题:学习成绩=90 分的同学用 A 表示,60-89 分之间的用 B 表示,60 分以下的用 C 表示。import java.util.*;public class lianxi05 public static void main(String args)int x;char grade;Scanner s=new Scanner(System.in);System.out.print(请输入一个成绩:);x=s.nextInt();grade=x=90?A:x=60?B:C;System.out.println(等级为:+grade);packagepackage akjava;

10、importimport java.io.BufferedReader;importimport java.io.IOException;importimport java.io.InputStreamReader;importimport java.util.Arrays;/import java.nio.Buffer;importimport java.util.Scanner;publicpublic classclass denji/*paramparam args*throwsthrows IOException*/publicpublic staticstatic voidvoid

11、 main(String args)throwsthrowsIOException BufferedReader s=newnew BufferedReader(newnewInputStreamReader(System.in);String art=s.readLine();System.out.println(art);Scanner scan=newnew Scanner(System.in);System.out.println(请输入你的数据:);intint n=scan.nextInt();charchar grade=(n=90?A:(n=60?B:C);System.out

12、.println(grade=+grade);【程序 6】题目:输入两个正整数 m 和 n,求其最大公约数和最小公倍数。/*在循环中,只要除数不等于 0,用较大数除以较小的数,将小的一个数作为下一轮循环的大数,取得的余数作为下一轮循环的较小的数,如此循环直到较小的数的值为0,返回较大的数,此数即为最大公约数,最小公倍数为两数之积除以最大公约数。*/import java.util.*;publicclasslianxi06public static void main(String args)inta,b,m;Scanner s=new Scanner(System.in);System.ou

13、t.print(键入一个整数:);a=s.nextInt();System.out.print(再键入一个整数:);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 deffpublic 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;pa

14、ckagepackage akjava;importimport java.util.Scanner;publicpublic classclass 公约数公倍数/*paramparam args*/privateprivate staticstatic intint deff(intint x,intint y)ifif(x=y)returnreturn x;ifif(y=0)returnreturn x;returnreturn deff(y,x%y);publicpublic staticstatic voidvoid main(String args)System.out.printl

15、n(请输入你的两个数:);Scanner scan=newnew Scanner(System.in);intint x=scan.nextInt();intint y=scan.nextInt();intint gongyueshu=deff(x,y);intint gongbeishu=x*y/gongyueshu;System.out.println(公约数=+gongyueshu+公倍数=+gongbeishu);【程序 7】题目:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。import java.util.*;public class lianxi07 publ

16、ic 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=0&ch=a&ch A&ch=Z)character+;else if(ch=)blank+;else other+;System.out.println(数字个数:+digital);System.out.println

17、(英文字母个数:+character);System.out.println(空格个数:+blank);System.out.println(其他字符个数:+other);packagepackage akjava;importimport java.io.BufferedReader;importimport java.io.IOException;importimport java.io.InputStreamReader;importimport java.util.Arrays;publicpublic classclass calzifu/*paramparam args*throw

18、sthrows IOException*/privateprivate staticstatic voidvoid cal(String art)charchar a=newnew charchar;intint x=0,y=0,z=0,q=0;forfor(intint i=0;iart.length();i+)/将字符串赋值给字符数组a=Arrays.copyOf(a,a.length+1);ai=art.charAt(i);forfor(intint j=0;ja.length;j+)ifif(aj=a|aj=A)x+;/字母elseelse ifif(aj=0)y+;/数字elseel

19、se ifif(aj=)z+;/空格elseelse q+;/其他System.out.println(字母=+x+数字=+y+空格=+z+其他=+q);publicpublic staticstatic voidvoid main(String args)throwsthrowsIOException BufferedReader str=newnew BufferedReader(newnewInputStreamReader(System.in);System.out.println(请输入字符串:);String art=str.readLine();cal(art);【程序 8】题目

20、:求 s=a+aa+aaa+aaaa+aa.a的值,其中 a 是一个数字。例如 2+22+222+2222+22222(此时共有 5 个数相加),几个数相加有键盘控制。import java.util.*;public 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();i

21、nt i=0;while(i n)b=b+a;sum=sum+b;a=a*10;+i;System.out.println(sum);【程序 9】题目:一个数如果恰好等于它的因子之和,这个数就称为完数。例如 6=123.编程找出 1000 以内的所有完数。public class lianxi09 public static void main(String args)System.out.println(1到 1000 的完数有:);for(int i=1;i1000;i+)int t=0;for(int j=1;j=i/2;j+)if(i%j=0)t=t+j;if(t=i)System.o

22、ut.print(i+);【程序 10】题目:一球从 100 米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第10 次落地时,共经过多少米?第10 次反弹多高?public class lianxi10 public static void main(String args)double h=100,s=100;for(int i=1;i10;i+)s=s+h;h=h/2;System.out.println(经过路程:+s);System.out.println(反弹高度:+h/2);【程序 11】题目:有 1、2、3、4 四个数字,能组成多少个互不相同且无重复数字的三位数?都

23、是多少?public class lianxi11 public static void main(String args)int count=0;for(int x=1;x5;x+)for(int y=1;y5;y+)for(int z=1;z 0&x 10&x 20&x 40&x 60&x 100)y=20*0.175+40*0.08+40*0.015+(x-100)*0.01;System.out.println(应该提取的奖金是 +y+万);【程序 13】题目:一个整数,它加上100 后是一个完全平方数,再加上 168 又是一个完全平方数,请问该数是多少?public class li

24、anxi13 public static void main(String args)for(int x=1;x100000;x+)if(Math.sqrt(x+100)%1=0)if(Math.sqrt(x+168)%1=0)System.out.println(x+加 100 是一个完全平方数,再加168 又是一个完全平方数);/*按题意循环应该从-100 开始(整数包括正整数、负整数、零),这样会多一个满足条件的数-99。但是我看到大部分人解这道题目时都把题中的“整数”理解成正整数,我也就随大流了。*/【程序 14】题目:输入某年某月某日,判断这一天是这一年的第几天?import jav

25、a.util.*;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 12|day 31)System.out

26、.println(输入错误,请重新输入!);e=1;while(e=1);for(int i=1;i 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 inputpublic int input()int value=0;Scanner s=new Scanner(System.in);value=s.nextInt();return value;【程序 16】题目:输出 9*9 口诀。public class lianxi16

27、 public static void main(String args)for(int i=1;i10;i+)for(int j=1;j=i;j+)System.out.print(j+*+i+=+j*i+);if(j*i10)System.out.print();System.out.println();【程序 17】题目:猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了。求第一天共摘了多少。public class lianxi17

28、 public static void main(String args)int x=1;for(int i=2;i=10;i+)x=(x+1)*2;System.out.println(猴子第一天摘了 +x+个桃子);/【程序 18】题目:两个乒乓球队进行比赛,各出三人。甲队为a,b,c 三人,乙队为x,y,z三人。已抽签决定比赛名单。有人向队员打听比赛的名单。a 说他不和 x 比,c 说他不和 x,z 比,请编程序找出三队赛手的名单。public class lianxi18 static char m=a,b,c;static char n=x,y,z;public static voi

29、d main(String args)for(int i=0;i m.length;i+)for(int j=0;j n.length;j+)if(mi=a&nj=x)continue;else if(mi=a&nj=y)continue;else if(mi=c&nj=x)|(mi=c&nj=z)continue;else if(mi=b&nj=z)|(mi=b&nj=y)continue;elseSystem.out.println(mi+vs +nj);【程序 19】题目:打印出如下图案(菱形)*public class lianxi19 public static void main(

30、String args)int H=7,W=7;/高和宽必须是相等的奇数for(int i=0;i(H+1)/2;i+)for(int j=0;jW/2-i;j+)System.out.print();for(int k=1;k(i+1)*2;k+)System.out.print(*);System.out.println();for(int i=1;i=H/2;i+)for(int j=1;j=i;j+)System.out.print();for(int k=1;k=W-2*i;k+)System.out.print(*);System.out.println();【程序 20】题目:有

31、一分数序列:2/1,3/2,5/3,8/5,13/8,21/13.求出这个数列的前 20 项之和。public class lianxi20 public static void main(String args)int x=2,y=1,t;double sum=0;for(int i=1;i=20;i+)sum=sum+(double)x/y;t=y;y=x;x=y+t;System.out.println(前 20 项相加之和是:【程序 21】题目:求 1+2!+3!+.+20!的和public class lianxi21 public static void main(String a

32、rgs)long sum=0;long fac=1;for(int i=1;i=20;i+)fac=fac*i;sum+=fac;System.out.println(sum);【程序 22】题目:利用递归方法求 5!。public class lianxi22 public static void main(String args)int n=5;rec fr=new rec();System.out.println(n+!=+fr.rec(n);class recpublic long rec(int n)long value=0;if(n=1)value=1;elsevalue=n*re

33、c(n-1);+sum);return value;【程序 23】题目:有 5 个人坐在一起,问第五个人多少岁?他说比第4 个人大 2 岁。问第 4 个人岁数,他说比第 3 个人大 2 岁。问第三个人,又说比第2 人大两岁。问第 2 个人,说比第一个人大两岁。最后问第一个人,他说是10 岁。请问第五个人多大?public class lianxi23 public static void main(String args)int age=10;for(int i=2;i=0;i-)System.out.print(chi);【程序 25】题目:一个5 位数,判断它是不是回文数。即12321 是

34、回文数,个位与万位相同,十位与千位相同。import java.util.*;public class lianxi25 public static void main(String args)Scanner s=new Scanner(System.in);int a;do System.out.print(请输入一个 5 位正整数:);a=s.nextInt();while(a99999);String ss=String.valueOf(a);char ch=ss.toCharArray();if(ch0=ch4&ch1=ch3)System.out.println(这是一个回文数);e

35、lse System.out.println(这不是一个回文数);/这个更好,不限位数import java.util.*;public class lianxi25a public static void main(String args)Scanner s=new Scanner(System.in);boolean is=true;System.out.print(请输入一个正整数:);long a=s.nextLong();String ss=Long.toString(a);char ch=ss.toCharArray();int j=ch.length;for(int i=0;ij

36、/2;i+)if(chi!=chj-i-1)is=false;if(is=true)System.out.println(这是一个回文数);else System.out.println(这不是一个回文数);【程序 26】题目:请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续判断第二个字母。import java.util.*;public class lianxi26 public static void main(String args)getChar tw=new getChar();System.out.println(请输入星期的第一个大写字母:);char c

37、h=tw.getChar();switch(ch)case M:System.out.println(Monday);break;case W:System.out.println(Wednesday);break;case F:System.out.println(Friday);break;case T:System.out.println(请输入星期的第二个字母:);char ch2=tw.getChar();if(ch2=U)System.out.println(Tuesday);else if(ch2=H)System.out.println(Thursday);else Syste

38、m.out.println(无此写法!);break;case S:System.out.println(请输入星期的第二个字母:);char ch2=tw.getChar();if(ch2=U)System.out.println(Sunday);else if(ch2=A)System.out.println(Saturday);else System.out.println(无此写法!);break;default:System.out.println(无此写法!);class getCharpublic char getChar()Scanner s=new Scanner(Syste

39、m.in);String str=s.nextLine();char ch=str.charAt(0);if(chZ)System.out.println(输入错误,请重新输入);ch=getChar();return ch;【程序 27】题目:求 100 之内的素数/使用除 sqrt(n)的方法求出的素数不包括2 和 3public class lianxi27 public static void main(String args)boolean b=false;System.out.print(2+);System.out.print(3+);for(int i=3;i100;i+=2)

40、for(int j=2;j=Math.sqrt(i);j+)if(i%j=0)b=false;break;elseb=true;if(b=true)System.out.print(i+);/该程序使用除 1 位素数得 2 位方法,运行效率高通用性差。public class lianxi27a public static void main(String args)int a=new int2,3,5,7;for(int j=0;j4;j+)System.out.print(aj+);boolean b=false;for(int i=11;i100;i+=2)for(int j=0;j4;

41、j+)if(i%aj=0)b=false;break;elseb=true;if(b=true)System.out.print(i+);【程序 28】题目:对 10 个数进行排序import java.util.*;public class lianxi28 public static void main(String args)Scanner s=new Scanner(System.in);int a=new int10;System.out.println(请输入 10 个整数:);for(int i=0;i10;i+)ai=s.nextInt();for(int i=0;i10;i+

42、)for(int j=i+1;j aj)int t=ai;ai=aj;aj=t;for(int i=0;i10;i+)System.out.print(ai+);【程序 29】题目:求一个 3*3 矩阵对角线元素之和import java.util.*;public class lianxi29 public static void main(String args)Scanner s=new Scanner(System.in);int a=new int33;System.out.println(请输入 9 个整数:);for(int i=0;i3;i+)for(int j=0;j3;j+

43、)aij=s.nextInt();System.out.println(输入的 3*3 矩阵是:);for(int i=0;i3;i+)for(int j=0;j3;j+)System.out.print(aij+);System.out.println();int sum=0;for(int i=0;i3;i+)for(int j=0;j=aa.length-1)bb.length-1=num;for(i=0;ia.length;i+)bi=ai;else for(i=0;i=ai)bi=ai;else bi=num;break;for(int j=i+1;jb.length;j+)bj=a

44、j-1;for(i=0;i b.length;i+)System.out.print(bi+);【程序 31】题目:将一个数组逆序输出。import java.util.*;public class lianxi31 public static void main(String args)Scanner s=new Scanner(System.in);int a=new int20;System.out.println(请输入多个正整数(输入-1 表示结束):);int i=0,j;do ai=s.nextInt();i+;while(ai-1!=-1);System.out.println

45、(你输入的数组为:);for(j=0;j=0;j=j-1)System.out.print(aj+);【程序 32】题目:取一个整数 a 从右端开始的 47 位。import java.util.*;public class lianxi32 public static void main(String args)Scanner s=new Scanner(System.in);System.out.print(请输入一个 7 位以上的正整数:);long a=s.nextLong();String ss=Long.toString(a);char ch=ss.toCharArray();in

46、t j=ch.length;if(j7)System.out.println(输入错误!);else System.out.println(截 取 从 右 端 开 始 的+chj-7+chj-6+chj-5+chj-4);4 7位 是:【程序 33】题目:打印出杨辉三角形(要求打印出10 行如下图)1 1 1 1 2 1 1 3 3 1 1 4 6 4 11 5 10 10 5 1public class lianxi33 public static void main(String args)int a=new int1010;for(int i=0;i10;i+)aii=1;ai0=1;f

47、or(int i=2;i10;i+)for(int j=1;ji;j+)aij=ai-1j-1+ai-1j;for(int i=0;i10;i+)for(int k=0;k2*(10-i)-1;k+)System.out.print();for(int j=0;j=i;j+)System.out.print(aij+);System.out.println();【程序 34】题目:输入 3 个数 a,b,c,按大小顺序输出。import java.util.Scanner;public class lianxi34 public static void main(String args)Sca

48、nner s=new Scanner(System.in);System.out.println(请输入 3 个整数:);int a=s.nextInt();int b=s.nextInt();int c=s.nextInt();if(a b)int t=a;a=b;b=t;if(a c)int t=a;a=c;c=t;if(b c)int t=b;b=c;c=t;System.out.println(从大到小的顺序输出:);System.out.println(a+b+c);【程序 35】题目:输入数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。import java.ut

49、il.*;public class lianxi35 public static void main(String args)int N=8;int a=new int N;Scanner s=new Scanner(System.in);int idx1=0,idx2=0;System.out.println(请输入 8 个整数:);for(int i=0;iN;i+)ai=s.nextInt();System.out.println(你输入的数组为:);for(int i=0;iN;i+)System.out.print(ai+);int max=a0,min=a0;for(int i=0

50、;i max)max=ai;idx1=i;if(ai min)min=ai;idx2=i;if(idx1!=0)int temp=a0;a0=aidx1;aidx1=temp;if(idx2!=N-1)int temp=aN-1;aN-1=aidx2;aidx2=temp;System.out.println(n交换后的数组为:);for(int i=0;iN;i+)System.out.print(ai+);【程序 36】题目:有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数import java.util.Scanner;public class lianxi36

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 应用文书 > 工作报告

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁