《最新java经典小程序-java入门100例!.doc》由会员分享,可在线阅读,更多相关《最新java经典小程序-java入门100例!.doc(145页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、Four short words sum up what has lifted most successful individuals above the crowd: a little bit more.-author-datejava经典小程序-java入门100例!1,编写程序,判断给定的某个年份是否是闰年。1,编写程序,判断给定的某个年份是否是闰年。 闰年的判断规则如下: (1)若某个年份能被4整除但不能被100整除,则是闰年。 (2)若某个年份能被400整除,则也是闰年。import java.util.Scanner;class Bissextile public static v
2、oid main(String arge) System.out.print(请输入年份); int year; /定义输入的年份名字为“year” Scanner scanner = new Scanner(System.in); year = scanner.nextInt(); if (year3000) System.out.println(年份有误,程序退出!); System.exit(0); if (year%4=0)&(year%100!=0)|(year%400=0) System.out.println(year+ is bissextile); else System.o
3、ut.println(year+ is not bissextile ); 2,给定一个百分制的分数,输出相应的等级。 90分以上 A级 8089 B级 7079 C级 6069 D级 60分以下 E级import java.util.Scanner;class Mark public static void main(String args) System.out.println(请输入一个分数); /定义输入的分数为“mark”,且分数会有小数 double mark; Scanner scanner = new Scanner(System.in); mark = scanner.nex
4、tDouble(); /判断是否有输入错误。 if(mark100) System.out.println(输入有误! ); System.exit(0); /*判断分数的等级 90分以上者A级, 8089分者 B级,7079分者 C级, 6069者 D级,60分以下 E级 */ if (mark=90) System.out.println(this mark is grade A ); else if (mark=80) System.out.println(this mark is grade B ); else if (mark=70) System.out.println(this
5、mark is grade C ); else if (mark=60) System.out.println(this mark is grade D ); else System.out.println(this mark is grade E ); 3,编写程序求 1+3+5+7+99 的和值。class he public static void main(String args) int number = 1; /初始值1,以后再+2递增上去 int sum = 0; for ( ; number 100; number+=2 ) sum += number; System.out.
6、println(1+3+5+7+99= +sum); 4、利用for循环打印 9*9 表?1*1=11*2=2 2*2=41*3=3 2*3=6 3*3=91*4=4 2*4=8 3*4=12 4*4=161*5=5 2*5=10 3*5=15 4*5=20 5*5=251*6=6 2*6=12 3*6=18 4*6=24 5*6=30 6*6=361*7=7 2*7=14 3*7=21 4*7=28 5*7=35 6*7=42 7*7=491*8=8 2*8=16 3*8=24 4*8=32 5*8=40 6*8=48 7*8=56 8*8=641*9=9 2*9=18 3*9=27 4*9
7、=36 5*9=45 6*9=54 7*9=63 8*9=72 9*9=81/循环嵌套,打印九九乘法表public class NineNine public static void main(Stringargs) System.out.println(); for (int j=1;j10;j+) for(int k=1;k10;k+) /老师的做法,判断语句里的 kj) break; /此处用 continue也可以,只是效率低一点 System.out.print( +k+X+j+=+j*k); System.out.println(); 6、输出所有的水仙花数,把谓水仙花数是指一个数
8、3位数,其各各位数字立方和等于其本身, 例如: 153 = 1*1*1 + 3*3*3 + 5*5*5 class DafodilNumber public static void main(String args) System.out.println(以下是所有的水仙花数); int number = 100; / 由于水仙花数是三位数,故由100开始算起 int i, j, k; / i j k 分别为number 的百位、十位、个位 for (int sum; number1000; number+) i=number/100; j=(number-i*100)/10; k=numbe
9、r-i*100-j*10; sum=i*i*i+j*j*j+k*k*k; if (sum=number) System.out.println(number+ is a dafodil number! ); 7、求 a+aa+aaa+.+aaaaaaaaa=? 其中a为1至9之中的一个数,项数也要可以指定。import java.util.Scanner;class Multinomial public static void main(String args) int a; /定义输入的 a int howMany; /定义最后的一项有多少个数字 Scanner scanner = new
10、Scanner(System.in); System.out.println(请输入一个 19 的 a 值); a = scanner.nextInt(); System.out.println(请问要相加多少项?); howMany = scanner.nextInt(); int sum=0; int a1=a; / 用来保存 a 的初始值 for (int i=1; i=howMany; i+) sum+= a; a = 10*a +a1; / 这表示a 的下一项 / 每次 a 的下一项都等于前一项*10,再加上刚输入时的 a ;注意,这时的 a 已经变化了。 System.out.pr
11、intln(sum=+sum); 8、求 2/1+3/2+5/3+8/5+13/8.前20项之和?class Sum public static void main(Sting args) double sum=0; double fenZi=2.0, fenMu=1.0; /初始的分子 (fenZi)2,分母(fenMu)1 for(int i=1; i=20; i+) sum += fenZi / fenMu ; fenMu = fenZi; /下一项的分母 上一项的分子 fenZi += fenMu; /下一项的分子 上一项的分子加分母 System.out.println(sum= s
12、um); 9、利用程序输出如下图形: * * * * * * * * * * * * * * * * * * * * * * * * *class Asterisk public static void main(String args) for (int i=1; i=13; i+=2) for(int j=1; j=i & i+j= 14; j+)System.out.print(* ); System.out.println(); / 换行 11、计算圆周率 PI44/3+4/5-4/7. 打印出第一个大于 3.1415小于 3.1416的值class Pi public static
13、void main(String args) double pi =0; /定义初始值 double fenZi = 4; /分子为4 double fenMu = 1; /第一个4,可看作分母为1 的分式,以后的分母每次递增2 for (int i = 0; i 1000000000; i+) /运行老久,减少循环次数会快很多,只是精确度小些 pi += (fenZi/fenMu) ; fenZi *= -1.0; /每项分子的变化是+4,4,+4,4 . fenMu += 2.0; /分母的变化是1,3,5,7, . 每项递加2 System.out.println(pi); 输出结果为p
14、i = 3.1415926525880504,应该不精确12、输入一个数据n,计算斐波那契数列(Fibonacci)的第n个值 1 1 2 3 5 8 13 21 34 规律:一个数等于前两个数之和/计算斐波那契数列(Fibonacci)的第n个值public class Fibonacci public static void main(String args) int n = Integer.parseInt(args0); int n1 = 1;/第一个数 int n2 = 1;/第二个数 int sum = 0;/和 if(n=0) System.out.println(参数错误!);
15、 return; if(n=2) sum = 1; else for(int i=3;i=n;i+) sum = n1+n2; n1 = n2; n2 = sum; System.out.println(sum); /计算斐波那契数列(Fibonacci)的第n个值/并把整个数列打印出来public class FibonacciPrint public static void main(String args) int n = Integer.parseInt(args0); FibonacciPrint t = new FibonacciPrint(); for(int i=1;i=n;i
16、+) t.print(i); public void print(int n) int n1 = 1;/第一个数 int n2 = 1;/第二个数 int sum = 0;/和 if(n=0) System.out.println(参数错误!); return; if(n=2) sum = 1; else for(int i=3;i=n;i+) sum = n1+n2; n1 = n2; n2 = sum; System.out.println(sum); 13、求1-1/3+1/5-1/7+1/9.的值。 a,求出前50项和值。 b,求出最后一项绝对值小于1e-5的和值。15、在屏幕上打印出
17、n行的金字塔图案,如,若n=5,则图案如下: * * * * */打印金字塔图案public class PrintStar public static void main(String args) int col = Integer.parseInt(args0); for(int i=1;i=col;i+)/i表示行数 /打印空格 for(int k=0;kcol-i;k+) System.out.print( ); /打印星星 for(int m=0;m2*i-1;m+) System.out.print(*); System.out.println(); 16、歌德巴赫猜想,任何一个大
18、于六的偶数可以拆分成两个质数的和 打印出所有的可能/任何一个大于六的偶数可以拆分成两个质数的和/打印出所有的可能public class Gedebahe public static void main(String args) int num = Integer.parseInt(args0); if(num=6) System.out.println(参数错误!); return; if(num%2!=0) System.out.println(参数错误!); return; Gedebahe g = new Gedebahe(); /1不是质数,2是偶数,因此从3开始循环 for(int
19、 i=3;i=num/2;i+) if(i%2=0)/如果为偶数,退出本次循环 continue; /当i与num-i都为质数时,满足条件,打印 if(g.isPrime(i) & g.isPrime(num-i) System.out.println(i+ + +(num-i)+ = +num); 第4章 数组1. 定义一个int型的一维数组,包含10个元素,分别赋一些随机整数,然后求出所有元素的最大值,最小值,平均值,和值,并输出出来。class ArrayNumber public static void main(String args) int arrayNumber; arrayN
20、umber = new int10; System.out.println(以下是随机的10个整数:); / 填入随机的 10个整数 for (int i =0; iarrayNumber.length; i+) arrayNumberi = (int)(100*Math.random(); System.out.print(arrayNumberi+ ); System.out.println(); int max = arrayNumber0; int min = arrayNumber0; int sum = 0; for (int i =0; iarrayNumber.length;
21、i+) if(max arrayNumberi) min = arrayNumberi; /求最小值 sum += arrayNumberi; System.out.println(其中 Max=+max+,Min=+min+,Sum=+sum+,Avg=+sum/10.0); 2.定义一个int型的一维数组,包含10个元素,分别赋值为110, 然后将数组中的元素都向前移一个位置,即,a0=a1,a1=a2,最后一个元素的值是原来第一个元素的值,然后输出这个数组。3. 定义一个int型的一维数组,包含40个元素,用来存储每个学员的成绩,循环产生40个0100之间的随机整数,将它们存储到一维数组
22、中,然后统计成绩低于平均分的学员的人数,并输出出来。4. (选做)承上题,将这40个成绩按照从高到低的顺序输出出来。5,(选做)编写程序,将一个数组中的元素倒排过来。例如原数组为1,2,3,4,5;则倒排后数组中的值为5,4,3,2,1。6,要求定义一个int型数组a,包含100个元素,保存100个随机的4位数。再定义一个 int型数组b,包含10个元素。统计a数组中的元素对10求余等于0的个数,保存 到b0中;对10求余等于1的个数,保存到b1中,依此类推。class Remain public static void main( String args) int a = new int10
23、0; /保存100个随机4位数到 a 中 for (int i = 0; i a.length; i+) ai = (int) (1000*Math.random(); /统计 a 数组中的元素对 10 求余的各个的数目 int b = new int10; int k,sum; for (int j = 0; j b.length; j+) for (k=0,sum=0; k 1.0E-4|N%2=0|N0) System.out.println(输入出错,格局只能是正奇数。请重新输入); else break; /老师的九宫格填写方法 int result = new intNN; /定义
24、保存九宫格的数组 int row = 0; /行 初始位置 int col = N/2; /列 初始位置,因为列由0开始,故N/2是中间位置 for (int i=1; i=N*N; i+) result rowcol = i; row-; col+; if (row=N)col-;row+=2; /行列都越界 else if (row=N)col = 0; /列越界 else if (resultrowcol != 0)col-;row+=2; /有冲突 /打印出九宫格 for (int i=0; iN; i+) for(int j=0; jN; j+)System.out.print(re
25、sultij+t); System.out.println(); /我个人的填格方式 int result2 = new intNN; /为免冲突,重新 new 一个数组 result2N/2N/2 = (N*N+1)/2; /先把中间值赋予中间位置 row = 0; /定义行及列的初始赋值位置。之前赋值的for对两个值有影响,故需重新定位 col = N/2; for (int i=1; i=N*N/2; i+) result2rowcol = i; /下面这句是把跟 i 对应的值放到格局对应的位置上 result2N-row-1N-col-1 = N*N+1-i; row-; col+;
26、if (row=N)col = 0; /列越界 else if (result2rowcol != 0)col-;row+=2; /有冲突 /这方法不可能出现行列两边都越界的情况,详情需要数学论证 System.out.println(); /再次打印出九宫格,以对比验证 for (int i=0; iN; i+) for(int j=0; jN; j+)System.out.print(result2ij+t); System.out.println(); 9,求一个3*3矩阵对角线元素之和 10,打印杨辉三角11. 约梭芬杀人法 把犯人围成一圈,每次从固定位置开始算起,杀掉第7个人,直到剩
27、下最后一个。11_2、用数组实现约瑟夫出圈问题。 n个人排成一圈,从第一个人开始报数,从1开始报,报到m的人出圈,剩下的人继续开始从1报数,直到所有的人都出圈为止。对于给定的n,m,求出所有人的出圈顺序。12. 判断随机整数是否是素数产生100个0-999之间的随机整数,然后判断这100个随机整数哪些是素数,哪些不是?public class PrimeTest public static void main(String args) for(int i=0;i100;i+) int num = (int)(Math.random()*1000); PrimeTest t = new Prim
28、eTest(); if(t.isPrime(num) System.out.println(num+ 是素数!); else System.out.println(num+ 不是素数!); System.out.println(); public boolean isPrime(int num) for(int i=2;i=num/2;i+) if(num%i=0) System.out.println(num+第一个被+i+整除!); return false; return true; 冒泡排序法:/按从大到小的排序int tmp = a0;for (int i=0; i a.length
29、; i+) for (int j=0; j a.length - i -1; j+) if (aj aj+1) tmp = aj; aj = aj+1; aj+1 = tmp; day06 练习某公司的雇员分为以下若干类:Employee:这是所有员工总的父类,属性:员工的姓名和生日月份。方法:getSalary(int month) 根据参数月份来确定工资,如果该月员工过生日,则公司会额外奖励100元。SalariedEmployee:Employee的子类,拿固定工资的员工。属性:月薪HourlyEmployee:Employee的子类,按小时拿工资的员工,每月工作超出160小时的部分按照1.5倍工资发放属性:每小时的工资、每月工作的小时数SalesEmployee:Employee的子类,销售人员,工资由月销售额和提成率决定属性:月销售额、提成率BasePlusSalesEmployee:SalesEmployee的子类,有固定底薪的销售人员,工资由底薪加上销售提成部分 属性:底薪。public class TestEmployee public stat