1、国家二级( JAVA)机试模拟试卷 36及答案与解析 一、基本操作题( 30分) 1 最大真约数是指一个数的 (除它本身之外 )最大约数。下面的程序是求一个数的最大真约数,请在程序的每条横线处填写一个语句,使程序的功能完整 (例如: 100的最大真约数是 50)。 注意:请勿改动 main()主方法和其他已有的语句内容,仅在横线处填入适当的语句。 public class MaxDiv public static void main(String args ) int a=100; _ while(i0) if(_) _ i-; System. out. print in (a+“的最大真约数
2、为 : “+i ); 二、简单应用题( 40分) 2 请完成下列 Java程序:计算下列级数之和,直到该项之绝对值小于 0.001为止。 S=1/1!-1 2!+1 3!-1 4!+ 注意:请勿改动 main()主方法和其他已有语句内容,仅在下划线处填入适当的语句。 程序运行结果如下: i=1 s=1.0 i=2 s=0.5 i=3 s=0.6666666666666666 1=4 s=0.625 i=5 s=0.6333333333333333 1=6 s=0.6319444444444444 public class ex28_2 public static void main(Strin
3、g args) double s=0.0,sign=-1.0,t,f=1.0; for(int i=1;i+) f=f*i; _; t=sign/f; if(_) break; s=s+t; System.out.println(“i=“+i+“ s=“+s); 三、综合应用题( 30分) 3 下面是一个 Applet程序,其功能是分析任意输入的字符串,将字符串中由空格隔开的字串提取并显示出来。要求,窗口中有一个输入文本框,用于接受输入的字符串,一个按钮,点击则开始分析,分析结果用图形方式打印在窗口下面的区域中。请改正程序中的错误 (有下划线的语句 ),使程序能输出正确的结果。 注意:不改动程
4、序的结构,不得增行或删行。 程序运行结果如下: import java.awt.*; import java.applet.*; import java.util.StringTokenizer; public class ex27_3 extends Applet private TextField tf; private Button btn; public void init() tf = new TextField(25); add(tf); btn= new Button(“分析 “); add(btn); resize(250, 200); public void paint(Gr
5、aphics g) String str = tf.getText(); StringTokenizer st = new StringTokenizer(tf); int n = 80; while (!st.hasMoreTokens() String tem = st.nextToken(); g.drawString(tem, n, 80); n += 20; public boolean action(Event e, Object o) if (o = “分析 “) repaint(); return true; else return false; ex27_3.html HTM
6、L HEAD TITLE ex27_3 /TITLE /HEAD BODY applet code=“ex27_3.class“ width=800 height=400 /applet /BODY /HTML 国家二级( JAVA)机试模拟试卷 36答案与解析 一、基本操作题( 30分) 1 【正确答案】 int i=a-1; a%i=0 break; 【试题解析】 本题主要考查 while循环语句、 break保留字和 求余运算符。解答本题的关键是熟练掌握 while循环语句、 break保留字和求余运算符的知识。在本题中, int i=a-1;语句的功能是定义变量 i, if(a i=0
7、)语句用来判断变量 i是否为a的约数, break;语句的功能是退出 while循环体,使程序的执行从 while循环体后的第 1条语句开始。 二、简单应用题( 40分) 2 【正确答案】 sign=-sign Math abs(t) 0 001 【试题解析】 本题主要考查 for循环和条件语句控制程序流程。解题关键是会根据公式写出相应的 算法解决问题。本题中,第 1个空,由于公式里每一项的符号都是交替变化的,所以这里需要改变符号;第 2个空,判断是否中断循环的条件,需要用 Math abs()方法来进行绝对值的比较。 三、综合应用题( 30分) 3 【正确答案】 new StringToke
8、nizer(str) St hasMoreTokens() g drawString(tem, 80, n) 【试题解析】 本题主要考查字符串的分割和 Applet图形界面相结合的综合应用。解题关键是熟悉字符串的分割方法,使用 StringTokenizer的对象来对 String类的对象进行分割。本题中,第 1处, StringTokenizer类的构造方法应该以String类的对象作为入口参数;第 2处,判断语句应该是当对象 st中还有分割串的时候则继续进行;第 3处, drawString()方法的参数第 2个表示输出字符串起始位置的横坐标,第 3个是纵坐标,如果 n作为横坐标,则输出的字符串会发生重叠。