JAVA经典编程50题附答案(共82页).doc





《JAVA经典编程50题附答案(共82页).doc》由会员分享,可在线阅读,更多相关《JAVA经典编程50题附答案(共82页).doc(82页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上JAVA经典编程50题初学JAVA坚持做完,JAVA完全可以入门,每天做4-5题就可以答案是本人自己做的,才初学浅,若有问题还希望有及时指出,感激不尽联系QQ: 网名:叫我雷锋【程序1】题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?package java50;public class Java1 /* * param 算法50题第一题。兔子问题,问题分析是一个斐波纳契数列,本题应该说有多种方法,我只写了其中一个,你自己可以试试用数组的方法,还有递归都可以。 */pu
2、blic static void main(String args) / TODO Auto-generated method stub/已经知道一月和二月的兔子数int a1=1;int a2=1;int a3,a4;/打印一二月的兔子数System.out.print(a1+ +a2);/从3月开始,到十二月的兔子数for(int i=3;i=12;i+)a3=a1+a2;a1=a2;a2=a3;/打印每个月的兔子数System.out.print( +a3);【程序2】题目:判断101-200之间有多少个素数,并输出所有素数。 程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个
3、数),如果能被整除, 则表明此数不是素数,反之是素数。package java50;import java.util.*;public class Java2 /* * param args * 求101到200之间的素数 * 素数是它除以2到sqr本身的数,没有能够整除他的 */public Java2()public void su(int a)public static void main(String args) / TODO Auto-generated method stubint a=new int 100; for(int i=100;i201;i+)for(int j=0;j
4、a.length;j+)aj=i;break;Java2 j2=new Java2();j2.su(a);【程序3】题目:打印出所有的 水仙花数 ,所谓 水仙花数 是指一个三位数,其各位数字立方和等于该数本身。例如:153是一个 水仙花数 ,因为153=1的三次方5的三次方3的三次方。package java50;public class Java3 /* * 【程序3】题目:打印出所有的 水仙花数 , * 所谓 水仙花数 是指一个三位数,其各位数字立方和等于该数本身。 * 例如:153是一个 水仙花数 , * 因为153=1的三次方5的三次方3的三次方。 */public static vo
5、id main(String args) / TODO Auto-generated method stubfor(int i=101;i1000;i+)int a=i%10;int b=(i/10)%10;int c=i/100;/System.out.print(a+b+c);if(i=a*a*a+b*b*b+c*c*c)System.out.println(i);【程序4】题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即
6、可。(2)如果n k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,重复执行第一步。(3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。package java50;import java.util.Scanner;public class Java4 /* * 程序4】题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。 * 程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成: * (1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。 * (2)如果n k,但n能被k整除,则应打印出k的值
7、,并用n除以k的商,作为新的正整数你n,重复执行第一步。 * (3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。 */public static void main(String args) / TODO Auto-generated method stubScanner s=new Scanner(System.in);int n=s.nextInt();eint k=2;while(n=k)if(n=k)System.out.println(k);break;elseif(n%k=0)System.out.print(k+*);n=n/k;elsek+;【程序5】题目:利用条
8、件运算符的嵌套来完成此题:学习成绩 =90分的同学用A表示,60-89分之间的用B表示,60分以下的用C表示。package java50;public class Java5 /* * 【程序5】 * 题目:利用条件运算符的嵌套来完成此题: * 学习成绩 =90分的同学用A表示, * 60-89分之间的用B表示,60分以下的用C表示。 */public static void main(String args) / TODO Auto-generated method stubint c=80;char cj=(c=90)?A:(c=60)?B:C;System.out.println(cj
9、);【程序6】题目:输入两个正整数m和n,求其最大公约数和最小公倍数。/*在循环中,只要除数不等于0,用较大数除以较小的数,将小的一个数作为下一轮循环的大数,取得的余数作为下一轮循环的较小的数,如此循环直到较小的数的值为0,返回较大的数,此数即为最大公约数,最小公倍数为两数之积除以最大公约数。* /import java.util.*;public class lianxi06 public static void main(String args) int a ,b,m;Scanner s = new Scanner(System.in);System.out.print( 键入一个整数:
10、); 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 =a & aa=A & aa=0 & aa=9)sz+;else qt+;/输出结果System.out.printl
11、n(字母有 +zm+个;);System.out.println(空格有 +kg+个;);System.out.println(数字有 +sz+个;);System.out.println(其它字符 +qt+个。);【程序8】题目:求s=a+aa+aaa+aaaa+aa.a的值,其中a是一个数字。例如2+22+222+2222+22222(此时共有5个数相加),几个数相加由键盘控制。package java50;import java.util.Scanner;public class Java8 /* *【程序8】 *题目:求s=a+aa+aaa+aaaa+aa.a的值,其中a是一个数字。
12、*例如2+22+222+2222+22222(此时共有5个数相加),几个数相加有键盘控制。 */public static void main(String args) / TODO Auto-generated method stubScanner ss=new Scanner(System.in);System.out.println(请输入a的值:);int a=ss.nextInt();System.out.println(请输入有几个数相加:);int g=ss.nextInt();int s=0;for(int i=1;i=g;i+)s=s+a;/System.out.print(
13、a=+a+ );a=a*10+2;/System.out.print(s=+s+ );/System.out.println(2+22+222+2222+22222);System.out.println(结果是+s);【程序9】题目:一个数如果恰好等于它的因子之和,这个数就称为 完数 。例如6=123.编程 找出1000以内的所有完数。package java50;public class Java9 /* * 【程序9】 * 题目:一个数如果恰好等于它的因子之和, * 这个数就称为 完数 。例如6=123.编程 * 找出1000以内的所有完数。 */public static void m
14、ain(String args) / TODO Auto-generated method stubfor(int i=6;i1000;i+)int h=0;for(int j=1;j=i;j+)if(i%j=0)/if(h!=0)System.out.print(h+);h=h+j;if(h=i)System.out.println(i);/6=1x2x3;/24=1x2x3x4;/28=1x2x4x7x14【程序10】题目:一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在 第10次落地时,共经过多少米?第10次反弹多高? package java50;public
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- JAVA 经典 编程 50 答案 82

限制150内