1、最新Java编程面试题全集共50道题+答案【程序1】题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?斐波那契数列:前面相邻两项之和,构成了后一项通项公式注:此时a1=1,a2=1,an=a(n-1)+a(n-2)(n=3,nN*)通项公式的推导斐波那契数列:1、1、2、3、5、8、13、21、如果设F(n)为该数列的第n项(nN+)。那么这句话可以写成如下形式:F(1) = 1,F(2)=1,F(n)=F(n-1)+F(n-2) (n3),显然这是一个线性递推数列。import java.uti
2、l.Scanner;public class X public static void main(String args) System.out.println(“请输入需要统计到的月份:”); Scanner sc = new Scanner(System.in);/ 让用户输入需要统计为止的月份 int n = sc.nextInt(); int num = new intn; num1 = 1; num2 = 1;/ 因为1,2月没有兔子产生,所以初始化为1 int i = 3; for (; i num.length; i+)/ 注意此处循环变量的初始化值为3,还需要注意的是i的作用域
3、 numi = numi - 1 + numi - 2; System.out.println(“第” + i + “月的兔子数量为:” + numi); System.out.println(“第” + n + “月的兔子数量为:” + (numi - 1 + numi - 2); / 因为循环内数组只能统计到n-1月份(数组的下标为0n-1) 【程序2】题目:判断101-200之间有多少个素数,并输出所有素数。程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除, 则表明此数不是素数,反之是素数。public class X public static void
4、main(String args) int count=0; for(int i=101;i=200;i+) int j=2;/j一定要在外层循环内部 for(;j=i;j+) if(i%j=0) break; if(i=j)/跳出循环有两种可能,1.循环完毕。2.break跳出 System.out.println(“素数为:”+i); count+; System.out.println(“素数个数为:”+count); 【程序3】题目:打印出所有的 “水仙花数 “,所谓 “水仙花数 “是指一个三位数,其各位数字立方和等于该数本身。例如:153是一个 “水仙花数 “,因为153=1的三次方
5、5的三次方3的三次方。public class lianxi03 public static void main(String args) int b1, b2, b3;for(int m=101; m1000; m+) b3 = m / 100;b2 = m % 100 / 10;b1 = m % 10;if(b3*b3*b3 + b2*b2*b2 + b1*b1*b1) = m) System.out.println(m+”是一个水仙花数”); 【程序4】题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按
6、下述步骤完成:(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。(2)如果n k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,重复执行第一步。(3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。import java.util.*;public class lianxi04public static void main(String args) Scanner s = new Scanner(System.in);System.out.print( “请键入一个正整数: “);int n = s.nextInt();int k=2;
7、System.out.print(n + “=” );while(k =90分的同学用A表示,60-89分之间的用B表示,60分以下的用C表示。import java.util.*;public class lianxi05 public static void main(String args) int x;char grade;Scanner s = new Scanner(System.in);System.out.print( “请输入一个成绩: “);x = s.nextInt();grade = x = 90 ? A: x = 60 ? B:C;System.out.println
8、(“等级为:”+grade);【程序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.pr
9、int( “键入一个整数: “);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 y) t = x;x = y;y = t;while(y != 0) if(x = y)
10、return x;else int k = x % y;x = y;y = k;return x;【程序7】题目:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。import java.util.*;public class lianxi07 public static void main(String args) int digital = 0;int character = 0;int other = 0;int blank = 0;char ch = null;Scanner sc = new Scanner(System.in);String s = sc.nextL
11、ine();ch = s.toCharArray();for(int i=0; i= 0 & ch = a & ch A & ch = Z) character +; else if(ch = ) blank +; else other +;System.out.println(“数字个数: ” + digital);System.out.println(“英文字母个数: ” + character);System.out.println(“空格个数: ” + blank);System.out.println(“其他字符个数:” + other );【程序8】题目:求s=a+aa+aaa+a
12、aaa+aaa的值,其中a是一个数字。例如2+22+222+2222+22222(此时共有5个数相加),几个数相加有键盘控制。import java.util.*;public class lianxi08 public static void main(String args) long a , b = 0, sum = 0;Scanner s = new Scanner(System.in);System.out.print(“输入数字a的值: “);a = s.nextInt();System.out.print(“输入相加的项数:”);int n = s.nextInt();int i
13、 = 0;while(i n) b = b + a;sum = sum + b;a = a * 10;+ i;System.out.println(sum);【程序9】题目:一个数如果恰好等于它的因子之和,这个数就称为 “完数 “。例如6=123.编程 找出1000以内的所有完数。public class lianxi09 public static void main(String args) System.out.println(“1到1000的完数有: “);for(int i=1; i1000; i+) int t = 0;for(int j=1; j= i/2; j+) if(i %
14、 j = 0) t = t + j;if(t = i) System.out.print(i + “ “);【程序10】题目:一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在 第10次落地时,共经过多少米?第10次反弹多高?public class lianxi10 public static void main(String args) double h = 100,s = 100;for(int i=1; i10; i+) s = s + h;h = h / 2;System.out.println(“经过路程:” + s);System.out.println(“
15、反弹高度:” + h / 2);【程序11】题目:有1、2、3、4四个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?public class lianxi11 public static void main(String args) int count = 0;for(int x=1; x5; x+) for(int y=1; y5; y+) for(int z=1; z 0 & x 10 & x 20 & x 40 & x 60 & x 100) y = 20 * 0.175 + 40 * 0.08 + 40 * 0.015 + (x 100) * 0.01;System.out
16、.println(“应该提取的奖金是 ” + y + “万”);【程序13】题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?public class lianxi13 public static void main(String args) for(int x =1; x100000; x+) if(Math.sqrt(x+100) % 1 = 0) if(Math.sqrt(x+268) % 1 = 0) System.out.println(x + “加100是一个完全平方数,再加168又是一个完全平方数”);/*按题意循环应该从-100开始
17、(整数包括正整数、负整数、零),这样会多一个满足条件的数-99。但是我看到大部分人解这道题目时都把题中的“整数”理解成正整数,我也就随大流了。*/【程序14】题目:输入某年某月某日,判断这一天是这一年的第几天?import java.util.*;public class lianxi14 public static void main(String args) int year, month, day;int days = 0;int d = 0;int e;input fymd = new input();do e = 0;System.out.print(“输入年:”);year =fy
18、md.input();System.out.print(“输入月:”);month = fymd.input();System.out.print(“输入天:”);day = fymd.input();if (year 0 | month 12 | day 31) System.out.println(“输入错误,请重新输入!”);e=1 ;while( e=1);for (int i=1; i y) int t = x;x = y;y = t;if(x z) int t = x;x = z;z = t;if(y z) int t = y;y = z;z = t;System.out.prin
19、tln( “三个数字由小到大排列为: “+x + ” ” + y + ” ” + z);class inputpublic int input() int value = 0;Scanner s = new Scanner(System.in);value = s.nextInt();return value;【程序16】题目:输出9*9口诀。public class lianxi16 public static void main(String args) for(int i=1; i10; i+) for(int j=1; j=i; j+) System.out.print(j + “*”
20、 + i + “=” + j*i + “ ” );if(j*i10)System.out.print(” “);System.out.println();【程序17】题目:猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个 第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下 的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了。求第一天共摘了多少。public class lianxi17 public static void main(String args) int x = 1;for(int i=2; i=10; i+) x = (x
21、+1)*2;System.out.println(“猴子第一天摘了 ” + x + ” 个桃子”);【程序18】题目:两个乒乓球队进行比赛,各出三人。甲队为a,b,c三人,乙队为x,y,z三人。已抽签决定比赛名单。有人向队员打听比赛的名单。a说他不和x比,c说他不和x,z比,请编程序找出三队赛手的名单。public class lianxi18 static char m = a, b, c ;static char n = x, y, z ;public static void main(String args) for (int i = 0; i m.length; i+) for (int j = 0; j n.length; j+) if (mi = a & nj = x) continue; else if (mi = a & nj = y) continue; else if (mi = c & nj = x)| (mi = c & nj = z) continue; else if (mi = b & nj = z)| (mi = b & nj = y) continue; elseSystem.out.println(m
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1