大家好,我是上海尚学堂Java培训老师,以下这些Java笔试真题是上海尚学堂Java学员在找工作中笔试遇到的真题。现在分享出来,也写了参考答案,供大家学习借鉴。想要更多学习资料和视频请留言联系或者上海尚学堂(shsxt.com)找美女小姐姐老师要。尚学堂Java300集和程序员修炼手册都是可以免费获得的,还有Java全套入门到架构师视频,还有双十一活动等等都是不可多得的干货中的干货。

好了,以下就是面试中遇到的Java真题,请尽情欣赏吧,最好可以动动手东东脑,敲一敲,写一写。

【程序1】

  题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少

  //这是一个菲波拉契数列问题

  

public class lianxi01 {

  public static void main(String[] args) {

  System.out.println("第1个月的兔子对数: 1");

  System.out.println("第2个月的兔子对数: 1");

  int f1 = 1, f2 = 1, f, M=24;

  for(int i=3; i<=M; i++) {

  f = f2;

  f2 = f1 + f2;

  f1 = f;

  System.out.println("第" + i +"个月的兔子对数: "+f2);

  }

  }

  }

  【程序2】

  题目:判断101-200之间有多少个素数,并输出所有素数。

  程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除, 则表明此数不是素数,反之是素数。

  

public class lianxi02 {

  public static void main(String[] args) {

  int count = 0;

  for(int i=101; i<200; i+=2) {

  boolean b = false;

  for(int j=2; j<=Math.sqrt(i); j++)

  {

  if(i % j == 0) { b = false; break; }

  else { b = true; }

  }

  if(b == true) {count ++;System.out.println(i );}

  }

  System.out.println( "素数个数是: " + count);

  }

  }

  【程序3】

  题目:打印出所有的 "水仙花数 ",所谓 "水仙花数 "是指一个三位数,其各位数字立方和等于该数本身。例如:153是一个 "水仙花数 ",因为153=1的三次方+5的三次方+3的三次方。

  

public class lianxi03 {

  public static void main(String[] args) {

  int b1, b2, b3;

  for(int m=101; m<1000; 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,然后按下述步骤完成:

  (1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。

  (2)如果n <> k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,重复执行第一步。

  (3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。

  

import java.util.*;

  public class lianxi04{

  public static void main(String[] args) {

  Scanner s = new Scanner(System.in);

  System.out.print( "请键入一个正整数: ");

  int n = s.nextInt();

  int k=2;

  System.out.print(n + "=" );

  while(k <= n) {

  if(k == n) {System.out.println(n);break;}

  else if( n % k == 0) {System.out.print(k + "*");n = n / k; }

  else k++;

  }

  }

  }

  【程序5】

  题目:利用条件运算符的嵌套来完成此题:学习成绩> =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("等级为:"+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.print( "键入一个整数: ");

  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 deff{

  public int deff(int x, int y) {

  int t;

  if(x < y) {

  t = x;

  x = y;

  y = t;

  }

  while(y != 0) {

  if(x == y) 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.nextLine();

  ch = s.toCharArray();

  for(int i=0; i

  if(ch >= '0' && ch <= '9') {

  digital ++;

  } else if((ch >= 'a' && ch <= 'z') || 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+aaaa+aa...a的值,其中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 = 0;

  while(i < n) {

  b = b + a;

  sum = sum + b;

  a = a * 10;

  ++ i;

  }

  System.out.println(sum);

  }

  }

  【程序9】

  题目:一个数如果恰好等于它的因子之和,这个数就称为 "完数 "。例如6=1+2+3.编程 找出1000以内的所有完数。

 

 public class lianxi09 {

  public static void main(String[] args) {

  System.out.println("1到1000的完数有: ");

  for(int i=1; i<1000; i++) {

  int t = 0;

  for(int j=1; j<= i/2; j++) {

  if(i % 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; i<10; i++) {

  s = s + h;

  h = h / 2;

  }

  System.out.println("经过路程:" + s);

  System.out.println("反弹高度:" + h / 2);

  }

  }

好了就先写这么多了,好好练习吧,后续上海尚学堂Java培训老师会继续添加的,请多多关注哦!想要更多Java学习资料和视频那就去上海尚学堂吧

Java面试中笔试题——Java代码真题,这些题会做,笔试完全可拿下!的更多相关文章

  1. JAVA面试中问及HIBERNATE与 MYBATIS的对比,在这里做一下总结

    我是一名java开发人员,hibernate以及mybatis都有过学习,在java面试中也被提及问道过,在项目实践中也应用过,现在对hibernate和mybatis做一下对比,便于大家更好的理解和 ...

  2. JAVA面试中问及HIBERNATE与 MYBATIS的对比,在这里做一下总结(转)

    hibernate以及mybatis都有过学习,在java面试中也被提及问道过,在项目实践中也应用过,现在对hibernate和mybatis做一下对比,便于大家更好的理解和学习,使自己在做项目中更加 ...

  3. 125条常见的java面试、笔试题大汇总

    1.抽象: 抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面.抽象并不打算了解所有问题,而仅仅是选择当中的一部分,临时不用部分细节.抽象包含两个方面,一是过程抽象. ...

  4. 带你全面了解高级 Java 面试中需要掌握的 JVM 知识点

    目录 JVM 内存划分与内存溢出异常 垃圾回收算法与收集器 虚拟机中的类加载机制 Java 内存模型与线程 虚拟机性能监控与故障处理工具 参考 带你全面了解高级 Java 面试中需要掌握的 JVM 知 ...

  5. Java面试,面试题

    Java面试,面试题 HashMap,HashTable,ConcurrentHash的共同点和区别 HashMap HashTable ConcurrentHashMap ArrayList和Lin ...

  6. Java面试中遇到的坑【填坑篇】

    看到大家对上篇<Java面试中遇到的坑>一文表现出强力的关注度,说明大家确实在面试中遇到了类似的难题.大家在文章留言处积极留言探讨面试中遇到的问题,其中几位同学还提出了自己的见解,我感到非 ...

  7. [转载]java面试中经常会被问到的一些算法的问题

    Java面试中经常会被问到的一些算法的问题,而大部分算法的理论及思想,我们曾经都能倒背如流,并且也能用开发语言来实现过, 可是很多由于可能在项目开发中应用的比较少,久而久之就很容易被忘记了,在此我分享 ...

  8. 收藏所用C#技术类面试、笔试题汇总

    技术类面试.笔试题汇总 注:标明*的问题属于选择性掌握的内容,能掌握更好,没掌握也没关系. 下面的参考解答只是帮助大家理解,不用背,面试题.笔试题千变万化,不要梦想着把题覆盖了,下面的题是供大家查漏补 ...

  9. JAVA面试中需要准备的点

    零基础入门学习Java,如何准备Java初级和高级的技术面试   本人最近几年一直在做java后端方面的技术面试官,而在最近两周,又密集了面试了一些java初级和高级开发的候选人,在面试过程中,我自认 ...

随机推荐

  1. Bootstrap-datepicker3官方文档中文翻译---Event/事件(原文链接 http://bootstrap-datepicker.readthedocs.io/en/latest/index.html)

    Events/事件 DatePicker在某些情况下触发一些事件.所有事件都拥有   传递给任何事件处理程序的  事件对象的    附加数据.(译者注:这里英语拗口,汉语也拗口,我用空格给大家断断句) ...

  2. SVN 通过Shell Bash 获取项目Reversion号码

    接上篇  Jenkins Vue项目自动构建以及构建后续操作 在项目构建完成后,需要提供当前构建的一个唯一标识的东西,并告诉我们的上线系统,这个唯一标识的东西可以让我们在回退线上版本的时候变得很有用, ...

  3. mysql更新字段内容

    update article set a_content = REPLACE(`a_content`,'www.abc.com','www.bcd.com')

  4. Taro父子组件通信

    父组件 testEvent = () =>{ console.log('abc123') } <Test test={1231323} onTestEvent={this.testEven ...

  5. 如何在本地数据中心安装Service Fabric for Windows集群

    概述 首先本文只是对官方文档(中文,英文)的一个提炼,详细的安装说明还请仔细阅读官方文档. 虽然Service Fabric的官方名称往往被加上Azure,但是实际上(估计很多人不知道)Service ...

  6. Metaphor of quotient space

    In James Munkres "Topology" Section 22, the quotient space is defined as below. Definition ...

  7. RESTful-2一分钟理解什么是REST和RESTful

    从事web开发工作有一小段时间,REST风格的接口,这样的词汇总是出现在耳边,然后又没有完全的理解,您是不是有和我相同的疑问呢?那我们一起来一探究竟吧! 就是用URL定位资源,用HTTP描述操作. 知 ...

  8. 2018-2019网络对抗技术 20165220 Exp4 恶意代码分析

    实践目标 监控你自己系统的运行状态,看有没有可疑的程序在运行. 分析一个恶意软件,就分析Exp2或Exp3中生成后门软件:分析工具尽量使用原生指令或sysinternals,systracer套件. ...

  9. <算法图解>读书笔记:第2章 选择排序

    第2章 选择排序 2.1 内存的工作原理 需要将数据存储到内存时,请求计算机提供存储空间,计算机会给一个存储地址.需要存储多项数据时,有两种基本方式-数组和链表 2.2 数组和链表 2.2.1 链表 ...

  10. ARM的编程模式

    ARM的编程模式 Linux ARM的工作状态 (主要指指令模式) 基本概述 32位架构 指令相关 ARM 32bit Thumb指令 16bit Thumb-2 16||32 bit 兼容 复位后开 ...