50道经典的JAVA编程题 (1-5)
后天java考试,现在闲着也是闲着,来做做java题吧。
前不久在网上看见了50道java算法编程题,感觉还不错,记得大一学C语言的时候做过一些,现在用java来回顾下吧,也算应付考试吧。
代码要是有啥不完美的地方还请各位积极指出啊,小的还是菜鸟啦,出错难免的哦~~~
暂时一篇帖子放5道吧,代码比较占地方,等全部做完了发一个目录吧
【程序1】 TestRabbit.java
题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?
1.程序分析: 兔子的规律为数列1,1,2,3,5,8,13,21....
package test50;/*** @author VellBibi*题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的总兔子对数为多少?*1.程序分析: 兔子的规律为数列1,1,2,3,5,8,13,21...*/public class TestRabbit {/*** @param m 总月数* @return 这月兔子对数*/public static int sumRabbitNumber(int m){int n = 1;//第0个月对数int e = 0;//第0个月对数int cup = 0;for(int i=1; i<m; i++){cup = n;n = e + n;e = cup;}return n;}public static void main(String[] args) {for(int i=1; i<=10; i++){System.out.print(sumRabbitNumber(i)+",");}}}
【程序2】 FindPrimeNumber.java
题目:判断101-200之间有多少个素数,并输出所有素数。
1.程序分析:判断素数的方法:用一个数分别去除2~sqrt(n)或者2~n/2,常用2~n/2,因为一个数的一半的平方大于其本身是从5开始的,解方程:n/2的平方>n .如果能被整除,
则表明此数不是素数,反之是素数。
package test50;/*** @author VellBibi*题目:判断101-200之间有多少个素数,并输出所有素数。*1.程序分析:判断素数的方法:用一个数分别去除2~sqrt(n)或者2~n/2,常用2~n/2,*因为一个数的一半的平方大于其本身是从5开始的,解方程:n/2的平方>n .如果能被整除,*则表明此数不是素数,反之是素数。*/public class FindPrimeNumber {/*** 判断n是不是质数* @param n* @return*/public static boolean isPrimeNumber(int n){if(n == 2) return true;for(int i=2; i<=n/2; i++){if(n % i == 0) return false;}return true;}public static void main(String[] args) {int n = 0;for(int i=101; i<=200; i++){if(isPrimeNumber(i)){n++;System.out.print(i + ",");}}System.out.println("\n101-200之间有"+n+"个素数");}}
【程序3】FindDaffodilNumber.java
题目:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。例如:
153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方。
1.程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。
package test50;/*** @author VellBibi*题目:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。例如:*153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方。*1.程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。*/public class FindDaffodilNumber {public static boolean isDaffodNumber(int n){char[] ch = String.valueOf(n).toCharArray();int cup = 0;for(int i=0; i<ch.length; i++){cup = cup + (int)Math.pow(Integer.parseInt(String.valueOf(ch[i])), 3) ;}return (cup == n);}public static void main(String[] args) {for(int i=100; i<1000; i++){if(isDaffodNumber(i)){System.out.print(i + ",");}}}}
【程序4】Explode.java
题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。
程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:
(1)运用两层循环。
(2)外循环得到2~n之间的所有质数,内循环将n循环除以质数,知道不能整除。
(3)要是内循环n等于1了就说明n被完全整除了。
package test50;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStreamReader;/*** @author VellBibi* 【程序4】Explode.java*题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。*程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:*(1)运用两层循环*(2)外循环得到2~n之间的所有质数,内循环将n循环除以质数,知道不能整除*(3)要是内循环n等于1了就说明n被完全整除了*/public class Explode {/*** 判断n是不是质数* @param n* @return*/public static boolean isPrimeNumber(int n){if(n == 2) return true;for(int i=2; i<=n/2; i++){if(n % i == 0) return false;}return true;}public static void main(String[] args) {BufferedReader buffer = new BufferedReader(new InputStreamReader(System.in));int N = 0;try {N = Integer.parseInt(buffer.readLine());} catch (IOException e) {e.printStackTrace();}System.out.print(N+"=");for(int i=2; i<N; i++){if(!isPrimeNumber(i)) continue;while(N%i == 0){System.out.print(i);N = N/i;if(N != 1) System.out.print("*");else break;}}if(N != 1) System.out.println(N);}}
【程序5】 ConditionOperator.java
题目:利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60-89分之间的用B表示,60分以下的用C表示。
1.程序分析:(a>b)?a:b这是条件运算符的基本例子。
package test50;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStreamReader;/*** @author VellBibi*【程序5】 ConditionOperator.java*题目:利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60-89分之间的用B表示,60分以下的用C表示。*1.程序分析:(a>b)?a:b这是条件运算符的基本例子。*/public class ConditionOperator {public static void main(String[] args) {BufferedReader buffer = new BufferedReader(new InputStreamReader(System.in));int N = 0;try {N = Integer.parseInt(buffer.readLine());} catch (IOException e) {e.printStackTrace();}System.out.println("学习成绩为:" + ((N < 60) ? "C" : (N < 90) ? "B" : "A"));}}
50道经典的JAVA编程题 (1-5)的更多相关文章
- 50道经典的JAVA编程题(汇总)
这是一次不可思议的编程历程.从2013年的最后一天开始做这份题,中间连续好几天的考试,包括java考试(今天考试的JAVA编程题),直到今天完成了.挺有成就感的...废话不多说了,来电实质性的吧. 全 ...
- 50道经典的JAVA编程题(46-50)
50道经典的JAVA编程题(46-50),最后五道题了,这是一个美妙的过程,编程真的能让我忘掉一切投入其中,感觉很棒.今天下午考完微机原理了,大三上学期就这样度过了,这学期算是解放了,可是感觉我还是没 ...
- 50道经典的JAVA编程题(41-45)
50道经典的JAVA编程题(41-45),苦逼的程序猿,晚上睡不着了编程吧~今天坚持做10道题!发现编程能是我快乐...O(∩_∩)O哈哈~能平静我烦乱的心,剩下5道题留到考试完了再做吧!该睡觉了.. ...
- 50道经典的JAVA编程题(36-40)
50道经典的JAVA编程题(36-40),今天晚上心情压抑,不爽,继续做题,管它明天考试,我继续我的java,一个周末都在看微机原理看得的很头疼啊~明天该挂科就挂吧,不在乎了~~~ [程序36] Ar ...
- 50道经典的JAVA编程题(31-35)
50道经典的JAVA编程题(31-35),今天考完了java,在前篇博客里面贴出了题了,见:<今天考试的JAVA编程题>.考完了也轻松了,下个星期一还考微机原理呢,啥都不会,估计今天就做到 ...
- 50道经典的JAVA编程题(26-30)
50道经典的JAVA编程题(26-30),这么晚了,早点睡了要,明早8点考java祝我好运吧!!!晚安~ [程序26]Ex26.java(跳过了,好没意思的题啊)题目:请输入星期几的第一个字母来判断一 ...
- 50道经典的JAVA编程题(21-25)
50道经典的JAVA编程题(21-25),明天早上java考试了,还是坚持做题吧...这题比老师的题好多了! [程序21]TestJieCheng.java题目:求1+2!+3!+...+20!的和1 ...
- 50道经典的JAVA编程题 (16-20)
50道经典的JAVA编程题 (16-20),用了快一个下午来做这10道题了,整理博客的时间貌似大于编程的时间啊..哈哈 [程序16]Nine.java 题目:输出9*9口诀. 1.程序分析:分行与列考 ...
- 50道经典的JAVA编程题 (11-15)
50道经典的JAVA编程题 (11-15),新年的第一天,继续啦...\(^o^)/~,这50道题都跨年了啊...哈哈 [程序11] TestTN.java 题目:有1.2.3.4个数字,能组成多少个 ...
- 50道经典的JAVA编程题 (6-10)
50道经典的JAVA编程题 (6-10),今晚做了10道了,累死了...感觉难度不是很大,就是不知道是不是最好的实现方法啊!希望大神们能给指点哈... [程序6]GCDAndLCM.java 题目:输 ...
随机推荐
- js和HTML结合(补充知识:如何防止文件缓存的js代码)
来自<javascript高级程序设计 第三版:作者Nicholas C. Zakas>的学习笔记(二) 使用html标签<script>可以把js嵌入到html页面中,让脚本 ...
- CrackMe_001
本系列文章的目的是从一个没有任何经验的新手的角度(其实就是我自己),一步步尝试将160个CrackMe全部破解,如果可以,通过任何方式写出一个类似于注册机的东西. 其中,文章中按照如下逻辑编排(解决如 ...
- hdu 4190
二分求箱子中的票数 然后判是否满足条件 主要为了纪念一下用优先队列9000ms水过 #include<cstdio> #include<climits> #inclu ...
- uva 147
一个简单的dp 面值是5的倍数 将面值都除5 因为输出问题wa .... #include <iostream> #include <cstring> #includ ...
- POJ1905Expanding Rods(二分)
http://poj.org/problem?id=1905 题意 :在两堵实心墙中间有一根杆,长度为L,然后给它加热,温度是n,则两墙之间的杆会弯曲,长度会变为L'=(1+n*C)*L,求前后两个状 ...
- POJ3096Surprising Strings(map)
题意:输入很多字符串,以星号结束.判断每个字符串是不是“Surprising Strings”,判断方法是:以“ZGBG”为例,“0-pairs”是ZG,GB,BG,这三个子串不相同,所以是“0-un ...
- codeforces #313 div1 B
模拟判定就可以了 判定字符串是否相等用hash来判断 QAQ 值得一提的是一开始我交的时候T了 结果我将递归的顺序调整了一下就A了 (并不知道为什么 #include<cstdio> #i ...
- GNU :6.47 Function Names as Strings
链接:http://gcc.gnu.org/onlinedocs/gcc/Function-Names.html#Function-Names GCC provides three magic var ...
- 如何保存ISE综合后的RTL schematic为pdf
如何保存ISE综合后的RTL schematic为pdf 2013-06-23 20:50:10 代码进行综合后,可以得到一个ngr文件,在ISE中打开该文件可以打开RTL schematic,这样每 ...
- GPS(2)关于位置的3个示例,实时获取GPS定位数据,求两个经纬点距离,邻近某个区域圆时警告
实时获取GPS定位数据 import android.app.Activity; import android.content.Context; import android.location.Loc ...






