竞赛java编程题50题有答案.docx

上传人:b****8 文档编号:9451457 上传时间:2023-05-19 格式:DOCX 页数:49 大小:85.22KB
下载 相关 举报
竞赛java编程题50题有答案.docx_第1页
第1页 / 共49页
竞赛java编程题50题有答案.docx_第2页
第2页 / 共49页
竞赛java编程题50题有答案.docx_第3页
第3页 / 共49页
竞赛java编程题50题有答案.docx_第4页
第4页 / 共49页
竞赛java编程题50题有答案.docx_第5页
第5页 / 共49页
竞赛java编程题50题有答案.docx_第6页
第6页 / 共49页
竞赛java编程题50题有答案.docx_第7页
第7页 / 共49页
竞赛java编程题50题有答案.docx_第8页
第8页 / 共49页
竞赛java编程题50题有答案.docx_第9页
第9页 / 共49页
竞赛java编程题50题有答案.docx_第10页
第10页 / 共49页
竞赛java编程题50题有答案.docx_第11页
第11页 / 共49页
竞赛java编程题50题有答案.docx_第12页
第12页 / 共49页
竞赛java编程题50题有答案.docx_第13页
第13页 / 共49页
竞赛java编程题50题有答案.docx_第14页
第14页 / 共49页
竞赛java编程题50题有答案.docx_第15页
第15页 / 共49页
竞赛java编程题50题有答案.docx_第16页
第16页 / 共49页
竞赛java编程题50题有答案.docx_第17页
第17页 / 共49页
竞赛java编程题50题有答案.docx_第18页
第18页 / 共49页
竞赛java编程题50题有答案.docx_第19页
第19页 / 共49页
竞赛java编程题50题有答案.docx_第20页
第20页 / 共49页
亲,该文档总共49页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

竞赛java编程题50题有答案.docx

《竞赛java编程题50题有答案.docx》由会员分享,可在线阅读,更多相关《竞赛java编程题50题有答案.docx(49页珍藏版)》请在冰点文库上搜索。

竞赛java编程题50题有答案.docx

竞赛java编程题50题有答案

【程序1】

题目:

古典问题:

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

;

publicclasslianxi04{

publicstaticvoidmain(String[]args){

Scanners=newScanner;

"请键入一个正整数:

");

intn=();

intk=2;

+"=");

while(k<=n){

if(k==n){elseif(n%k==0){+"*");n=n/k;}

elsek++;

}

}

}

 

packageakjava;

importclassFenJie{

/**

*@paramargs

*/

publicstaticvoidmain(String[]args){

"请输入你要分解的整数:

");

Scannerscan=newScanner;

intn=();

intk=2;

"=");

for(;n>1;){

;

publicclasslianxi05{

publicstaticvoidmain(String[]args){

intx;

chargrade;

Scanners=newScanner;

"请输入一个成绩:

");

x=();

grade=x>=90'A'

:

x>=60'B'

:

'C';

"等级为:

"+grade);

}

}

 

packageakjava;

importclassdenji{

/**

*@paramargs

*@throwsIOException

*/

publicstaticvoidmain(String[]args)throwsIOException{

BufferedReaders=newBufferedReader(newInputStreamReader);

Stringart=();

Scannerscan=newScanner;

"请输入你的数据:

");

intn=();

chargrade=(n>=90'A':

(n>=60'B':

'C'));

"grade="+grade);

}

}

 

 

【程序6】

题目:

输入两个正整数m和n,求其最大公约数和最小公倍数。

/**在循环中,只要除数不等于0,用较大数除以较小的数,将小的一个数作为下一轮循环的大数,取得的余数作为下一轮循环的较小的数,如此循环直到较小的数的值为0,返回较大的数,此数即为最大公约数,最小公倍数为两数之积除以最大公约数。

*/

import.*;

publicclasslianxi06{

publicstaticvoidmain(String[]args){

inta,b,m;

Scanners=newScanner;

"键入一个整数:

");

a=();

"再键入一个整数:

");

b=();

deffcd=newdeff();

m=(a,b);

intn=a*b/m;

"最大公约数:

"+m);

"最小公倍数:

"+n);

}

}

classdeff{

publicintdeff(intx,inty){

intt;

if(x

t=x;

x=y;

y=t;

}

while(y!

=0){

if(x==y)returnx;

else{

intk=x%y;

x=y;

y=k;

}

}

returnx;

}

}

packageakjava;

importclass公约数公倍数{

/**

*@paramargs

*/

privatestaticintdeff(intx,inty){

if(x==y)returnx;

if(y==0)returnx;

returndeff(y,x%y);

}

publicstaticvoidmain(String[]args){

"请输入你的两个数:

");

Scannerscan=newScanner;

intx=();

inty=();

intgongyueshu=deff(x,y);

intgongbeishu=x*y/gongyueshu;

"公约数="+gongyueshu+"公倍数="+gongbeishu);

}

}

 

【程序7】

题目:

输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。

import.*;

publicclasslianxi07{

publicstaticvoidmain(String[]args){

intdigital=0;

intcharacter=0;

intother=0;

intblank=0;

char[]ch=null;

Scannersc=newScanner;

Strings=();

ch=();

for(inti=0;i<;i++){

if(ch>='0'&&ch<='9'){

digital++;

}elseif((ch>='a'&&ch<='z')||ch>'A'&&ch<='Z'){

character++;

}elseif(ch==''){

blank++;

}else{

other++;

}

}

"数字个数:

"+digital);

"英文字母个数:

"+character);

"空格个数:

"+blank);

"其他字符个数:

"+other);

}

}

 

packageakjava;

importclasscalzifu{

/**

*@paramargs

*@throwsIOException

*/

privatestaticvoidcal(Stringart){

char[]a=newchar[]{};

intx=0,y=0,z=0,q=0;

for(inti=0;i<();i++){

.a的值,其中a是一个数字。

例如2+22+222+2222+22222(此时共有5个数相加),几个数相加有键盘控制。

import.*;

publicclasslianxi08{

publicstaticvoidmain(String[]args){

longa,b=0,sum=0;

Scanners=newScanner;

"输入数字a的值:

");

a=();

"输入相加的项数:

");

intn=();

inti=0;

while(i

b=b+a;

sum=sum+b;

a=a*10;

++i;

}

 

【程序9】

题目:

一个数如果恰好等于它的因子之和,这个数就称为"完数"。

例如6=1+2+3.编程找出1000以内的所有完数。

publicclasslianxi09{

publicstaticvoidmain(String[]args){

"1到1000的完数有:

");

for(inti=1;i<1000;i++){

intt=0;

for(intj=1;j<=i/2;j++){

if(i%j==0){

t=t+j;

}

}

if(t==i){

+"");

}

}

}

【程序10】

题目:

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

publicclasslianxi10{

publicstaticvoidmain(String[]args){

doubleh=100,s=100;

for(inti=1;i<10;i++){

s=s+h;

h=h/2;

}

"经过路程:

"+s);

"反弹高度:

"+h/2);

}

}

【程序11】

题目:

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

publicclasslianxi11{

publicstaticvoidmain(String[]args){

intcount=0;

for(intx=1;x<5;x++){

for(inty=1;y<5;y++){

for(intz=1;z<5;z++){

if(x!

=y&&y!

=z&&x!

=z){

count++;

+y*10+z);

}

}

}

}

"共有"+count+"个三位数");

}

}

【程序12】

题目:

企业发放的奖金根据利润提成。

利润(I)低于或等于10万元时,奖金可提10%;利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可可提成%;20万到40万之间时,高于20万元的部分,可提成5%;40万到60万之间时高于40万元的部分,可提成3%;60万到100万之间时,高于60万元的部分,可提成%,高于100万元时,超过100万元的部分按1%提成,从键盘输入当月利润,求应发放奖金总数

import.*;

publicclasslianxi12{

publicstaticvoidmain(String[]args){

doublex=0,y=0;

"输入当月利润(万):

");

Scanners=newScanner;

x=();

if(x>0&&x<=10){

y=x*;

}elseif(x>10&&x<=20){

y=10*+(x-10)*;

}elseif(x>20&&x<=40){

y=10*+10*+(x-20)*;

}elseif(x>40&&x<=60){

y=10*+10*+20*+(x-40)*;

}elseif(x>60&&x<=100){

y=20*+20*+20*+(x-60)*;

}elseif(x>100){

y=20*+40*+40*+(x-100)*;

}

"应该提取的奖金是"+y+"万");

}

}

【程序13】

题目:

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

publicclasslianxi13{

publicstaticvoidmain(String[]args){

for(intx=1;x<100000;x++){

if(x+100)%1==0){

if(x+168)%1==0){

+"加100是一个完全平方数,再加168又是一个完全平方数");

}

}

}

}

}

/*按题意循环应该从-100开始(整数包括正整数、负整数、零),这样会多一个满足条件的数-99。

但是我看到大部分人解这道题目时都把题中的“整数”理解成正整数,我也就随大流了。

*/

【程序14】

题目:

输入某年某月某日,判断这一天是这一年的第几天

import.*;

publicclasslianxi14{

publicstaticvoidmain(String[]args){

intyear,month,day;

intdays=0;

intd=0;

inte;

inputfymd=newinput();

do{

e=0;

"输入年:

");

year=();

"输入月:

");

month=();

"输入天:

");

day=();

if(year<0||month<0||month>12||day<0||day>31){

"输入错误,请重新输入!

");

e=1;

}

}while(e==1);

for(inti=1;i

switch(i){

case1:

case3:

case5:

case7:

case8:

case10:

case12:

days=31;

break;

case4:

case6:

case9:

case11:

days=30;

break;

case2:

if((year%400==0)||(year%4==0&&year%100!

=0)){

days=29;

}else{

days=28;

}

break;

}

d+=days;

}

+"-"+month+"-"+day+"是这年的第"+(d+day)+"天。

");

}

}

classinput{

publicintinput(){

intvalue=0;

Scanners=newScanner;

value=();

returnvalue;

}

}

【程序15】

题目:

输入三个整数x,y,z,请把这三个数由小到大输出。

import.*;

publicclasslianxi15{

publicstaticvoidmain(String[]args){

inputfnc=newinput();

intx=0,y=0,z=0;

"输入第一个数字:

");

x=();

"输入第二个数字:

");

y=();

"输入第三个数字:

");

z=();

if(x>y){

intt=x;

x=y;

y=t;

}

if(x>z){

intt=x;

x=z;

z=t;

}

if(y>z){

intt=y;

y=z;

z=t;

}

"三个数字由小到大排列为:

"+x+""+y+""+z);

}

}

classinput{

publicintinput(){

intvalue=0;

Scanners=newScanner;

value=();

returnvalue;

}

}

【程序16】

题目:

输出9*9口诀。

publicclasslianxi16{

publicstaticvoidmain(String[]args){

for(inti=1;i<10;i++){

for(intj=1;j<=i;j++){

+"*"+i+"="+j*i+"");

if(j*i<10){"");}

}

}

}

}

【程序17】

题目:

猴子吃桃问题:

猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个第二天早上又将剩下的桃子吃掉一半,又多吃了一个。

以后每天早上都吃了前一天剩下的一半零一个。

到第10天早上想再吃时,见只剩下一个桃子了。

求第一天共摘了多少。

publicclasslianxi17{

publicstaticvoidmain(String[]args){

intx=1;

for(inti=2;i<=10;i++){

x=(x+1)*2;

}

"猴子第一天摘了"+x+"个桃子");/

}

}

【程序18】

题目:

两个乒乓球队进行比赛,各出三人。

甲队为a,b,c三人,乙队为x,y,z三人。

已抽签决定比赛名单。

有人向队员打听比赛的名单。

a说他不和x比,c说他不和x,z比,请编程序找出三队赛手的名单。

publicclasslianxi18{

staticchar[]m={'a','b','c'};

staticchar[]n={'x','y','z'};

publicstaticvoidmain(String[]args){

for(inti=0;i<;i++){

for(intj=0;j<;j++){

if(m[i]=='a'&&n[j]=='x'){

continue;

}elseif(m[i]=='a'&&n[j]=='y'){

continue;

}elseif((m[i]=='c'&&n[j]=='x')

||(m[i]=='c'&&n[j]=='z')){

continue;

}elseif((m[i]=='b'&&n[j]=='z')

||(m[i]=='b'&&n[j]=='y')){

continue;

}else

+"vs"+n[j]);

}

}

}

}

【程序19】

题目:

打印出如下图案(菱形)

*

***

*****

*******

*****

***

*

publicclasslianxi19{

publicstaticvoidmain(String[]args){

intH=7,W=7;.求出这个数列的前20项之和。

publicclasslianxi20{

publicstaticvoidmain(String[]args){

intx=2,y=1,t;

doublesum=0;

for(inti=1;i<=20;i++){

sum=sum+(double)x/y;

t=y;

y=x;

x=y+t;

}

"前20项相加之和是:

"+sum);

}

}

【程序21】

题目:

求1+2!

+3!

+...+20!

的和

publicclasslianxi21{

publicstaticvoidmain(String[]args){

longsum=0;

longfac=1;

for(inti=1;i<=20;i++){

fac=fac*i;

sum+=fac;

}

【程序22】

题目:

利用递归方法求5!

publicclasslianxi22{

publicstaticvoidmain(String[]args){

intn=5;

recfr=newrec();

"!

="+(n));

}

}

classrec{

publiclongrec(intn){

longvalue=0;

if(n==1){

value=1;

}else{

value=n*rec(n-1);

}

returnvalue;

}

}

【程序23】

题目:

有5个人坐在一起,问第五个人多少岁他说比第4个人大2岁。

问第4个人岁数,他说比第3个人大2岁。

问第三个人,又说比第2人大两岁。

问第2个人,说比第一个人大两岁。

最后问第一个人,他说是10岁。

请问第五个人多大

publicclasslianxi23{

publicstaticvoidmain(String[]args){

intage=10;

for(inti=2;i<=5;i++){

age=age+2;

}

【程序24】

题目:

给一个不多于5位的正整数,要求:

一、求它是几位数,二、逆序打印出各位数字。

;

publicclasslianxi24{

publicstaticvoidmain(String[]args){

Scanners=newScanner;

"请输入一个正整数:

");

longa=();

Stringss=(a);

char[]ch=();

intj=;

+"是一个"+j+"位数。

");

"按逆序输出是:

");

for(inti=j-1;i>=0;i--){

}

}

}

【程序25】

题目:

一个5位数,判断它是不是回文数。

即12321是回文数,个位与万位相同,十位与千位相同。

import.*;

publicclasslianxi25{

publicstaticvoidmain(String[]args){

Scanners=newScanner;

inta;

do{

"请输入一个5位正整数:

");

a=();

}while(a<10000||a>99999);

Stringss=(a);

char[]ch=();

if(ch[0]==ch[4]&&ch[1]==ch[3]){

"这是一个回文数");}

else{"这不是一个回文数");}

}

}

;

publicclasslianxi25a{

publicstaticvoidmain(String[]args){

Scanners=newScanner;

booleanis=true;

"请输入一个正整数:

");

longa=();

Stringss=(a);

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 解决方案 > 学习计划

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2