一.选择题
1、【C语言】能正确表示逻辑关系: “a ≥=1 0 或 a ≤ 0” 的 C 语言表达式是( D )
A. a >= 10 or a = 10 B. a >= 10 | a <= 0
C. a >= 10 && a = 10 D. a >= 10 || a <= 0
解析:A:C语言中没有类似or这个关键字 B:或,对应的符号是两个竖线 || C:&&是并且的意思。
2、【C语言】在计算机系统里面,数值用( B )存储。
A. 源码 B. 补码
C.反码 D.Unicode 码
解析:计算机当中存储的都是补码的形式,正数的原码,反码,补码都是一样的。
3、以下代码的循环次数是 ( D )
public class Test {
public static void main(String args[]) {
int i = 7;
do {
System.out.println(--i);//1
--i;//2
} while (i != 0);//3
System.out.println(i);
}
}
A: 0 B: 1
C: 7 D: 无限次
解析:
4、下列选项中属于面向对象主要特征的是( A )。
A:继承 B:自顶向下
C:模块化 D:逐步求精
解析:面向对象的几种基本特征:继承,封装,多态,组合。
5、下面的方法,当输入为2的时候返回值是多少? ( D )
public static int getValue(int i) {
int result = 0;
switch (i) {
case 1:
result = result + i;//1
case 2:
result = result + i * 2;//2
case 3:
result = result + i * 3;//3
}
return result;
}
A: 0 B: 2
C: 4 D: 10
解析:主要考察break.当i为2的时候,程序直接走到case 2这一行当中,result = 0+4;但是没有break.程序会继续执行到3 处,result = 4+6=10;最后执行结束!
二.代码题
1、编程求 1~10000 之间的所有“完全数”,完全数是该数的所有因子之和等于该数的数。例如,6 的因子有 1、2、 3,且 6=1+2+3,所以 6 是完全数。
public class Day04 {
public static boolean perfectNumber(int num){
int sum = 0;
for(int i = 1;i <= num/2;i++) {
if(num % i == 0)
sum += i;
}
return sum == num;
}
public static void main(String[] args) {
for(int i = 1;i < 10000;i++){
if(perfectNumber(i)){
System.out.println(i);
}
}
}
}
2、猴子吃桃问题。猴子第一天摘下若干个桃子,当时就吃了一半,还不过瘾,就又吃了一个。第二天又将剩下的桃子吃掉一半,又多吃了一个。以后每天都吃前一天剩下的一半零一个。到第 10 天在想吃的时候就剩一个桃子了,求第 一天共摘下来多少个桃子?
public class Day05 {
public static void main(String[] args) {
//int total=1;
//int day=10;
//for (int i = 10; i > 0; i--) {
//System.out.println("第" + day + "天,有桃子" + total + "颗");
//total = (total + 1) * 2;
//day--;
//}
int sum = 1;
for(int i = 1;i < 10;i++){
sum = (sum + 1)*2;
}
System.out.println("第一天有" + sum + "个桃子");
}
}