JAVA算法100例,全源码

上传人:新** 文档编号:431159577 上传时间:2023-01-12 格式:DOC 页数:25 大小:130.50KB
返回 下载 相关 举报
JAVA算法100例,全源码_第1页
第1页 / 共25页
JAVA算法100例,全源码_第2页
第2页 / 共25页
JAVA算法100例,全源码_第3页
第3页 / 共25页
JAVA算法100例,全源码_第4页
第4页 / 共25页
JAVA算法100例,全源码_第5页
第5页 / 共25页
点击查看更多>>
资源描述

《JAVA算法100例,全源码》由会员分享,可在线阅读,更多相关《JAVA算法100例,全源码(25页珍藏版)》请在金锄头文库上搜索。

1、wordJAVA经典算法40题【程序1】 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第四个月后每个月又生一对兔子,假设兔子都不死,问每个月的兔子总数为多少? 1.程序分析: 兔子的规律为数列1,1,2,3,5,8,13,21. publicclass exp2publicstaticvoid main(String args)int i=0;for(i=1;i=20;i+)System.out.println(f(i);publicstaticint f(int x)if(x=1 | x=2)return 1;elsereturnf(x-1)+f(x-2);或

2、publicclass exp2publicstaticvoid main(String args)int i=0;math mymath = new math();for(i=1;i=20;i+)System.out.println(mymath.f(i);class mathpublicint f(int x)if(x=1 | x=2)return 1;elsereturn f(x-1)+f(x-2);【程序2】 题目:判断101-200之间有多少个素数,并输出所有素数。 1.程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除, 如此明确此数不是素数,反之是素数

3、。 publicclass exp2publicstaticvoid main(String args)int i=0;math mymath = new math();for(i=2;i=200;i+)if(mymath.iszhishu(i)=true)System.out.println(i);class mathpublicint f(int x)if(x=1 | x=2)return 1;elsereturn f(x-1)+f(x-2);publicboolean iszhishu(int x)for(int i=2;i=x/2;i+)if (x % 2=0 )returnfalse

4、;returntrue;【程序3】 题目:打印出所有的 水仙花数 ,所谓 水仙花数 是指一个三位数,其各位数字立方和等于该数本身。例如:153是一个 水仙花数 ,因为153=1的三次方5的三次方3的三次方。 1.程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。 publicclass exp2publicstaticvoid main(String args)int i=0;math mymath = new math();for(i=100;i=999;i+)if(mymath.shuixianhua(i)=true)System.out.println(i);

5、class mathpublicint f(int x)if(x=1 | x=2)return 1;elsereturn f(x-1)+f(x-2);publicboolean iszhishu(int x)for(int i=2;i=x/2;i+)if (x % 2=0 )returnfalse;returntrue;publicboolean shuixianhua(int x)int i=0,j=0,k=0; i=x / 100; j=(x % 100) /10; k=x % 10;if(x=i*i*i+j*j*j+k*k*k)returntrue;elsereturnfalse;【程序

6、4】 题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。 程序分析:对n进展分解质因数,应先找到一个最小的质数k,然后按下述步骤完成: (1)如果这个质数恰等于n,如此说明分解质因数的过程已经完毕,打印出即可。 (2)如果n k,但n能被k整除,如此应打印出k的值,并用n除以k的商,作为新的正整数你,重复执行第一步。 (3)如果n不能被k整除,如此用k+1作为k的值,重复执行第一步。 publicclass exp2public exp2()publicvoid fengjie(int n)for(int i=2;i =90分的同学用A表示,60-89分之间的用B表示,

7、60分以下的用C表示。 1.程序分析:(a b)?a:b这是条件运算符的根本例子。 import javax.swing.*;publicclass ex5 publicstaticvoid main(String args) String str=; str=JOptionPane.showInputDialog(请输入N的值输入exit退出:);int N; N=0;try N=Integer.parseInt(str); catch(NumberFormatException e) e.printStackTrace(); str=(N90?A:(N60?B:C); System.out

8、.println(str); 【程序6】 题目:输入两个正整数m和n,求其最大公约数和最小公倍数。 1.程序分析:利用辗除法。 最大公约数:publicclass monDivisorpublicstaticvoid main(String args) monDivisor(24,32); staticint monDivisor(int M, int N) if(N0|M0) System.out.println(ERROR!);return -1; if(N=0) System.out.println(the biggest mon divisor is :+M);return M; re

9、turnmonDivisor(N,M%N); 最小公倍数和最大公约数:import ; publicclass CandC /下面的方法是求出最大公约数publicstaticint gcd(int m, int n) while (true) if (m = m % n) = 0) return n; if (n = n % m) = 0) return m; publicstaticvoid main(String args) throws Exception /取得输入值/Scanner chin = new Scanner(System.in); /int a = chin.nextI

10、nt(), b = chin.nextInt(); int a=23; int b=32;int c = gcd(a, b); System.out.println(最小公倍数: + a * b / c + n最大公约数: + c); 【程序7】 题目:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。 1.程序分析:利用while语句,条件为输入的字符不为 n . import java.util.Scanner;publicclass ex7 publicstaticvoidmain(String args) System.out.println(请输入字符串:); Sca

11、nner scan=new Scanner(System.in); String str=scan.next(); String E1=u4e00-u9fa5; String E2=a-zA-Z;int countH=0;int countE=0;char arrChar=str.toCharArray(); String arrStr=new StringarrChar.length;for (int i=0;iarrChar.length ;i+ ) arrStri=String.valueOf(arrChari); for (String i: arrStr ) if (i.matches(E1) countH+; if (i.matches(E2)

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号