等级考试(笔试)虽然知识面比较广,但不是很深,基础部分考的是你日常操作的能力,程序设计多数是考你的细心。辛辛苦苦准备了大半年,又经过2个小时的考场之战,交卷之后还很“自美”,成绩单上的“不及格”让你一时不敢相信自己的眼睛。 eF gb6dSh
[4+a 1/^
当对着答 案细细“品味”时,你会N次的感叹……原来“罪魁祸首”是“不细心”。 JXI+k.fi
h\: tUEg#J
综观这四年来的考题,对容易出错的典型题例作了汇总和分析,也好给以后参加二级C考试的朋友增加点免疫力吧。本文将分三次刊登。 dKN3ZCw*gF
^0BF2&Zx
第一类,审题不清 XQ4^:3Yc
aF4V|?+
1.审题时的一字之差。 e5:l 6`
aS1P]&
一定要搞清题意,题目让我们选择的是“正确”还是“不正确”的;“能”还是“不能”的;本来要求选出一个错误的答 案,但题目中没有“错误”字样,而是说 “……请选出不正确的一项”,一不小心你就可能会把选项中最前面一个“正确”的选为答 案,因“正确”的有三个选项,当然觉得很容易,就这样,“错误”轻易地从你的笔尖溜走了。 J?HZ,7X:
B2Awdw3=g
2.不注意文字部分的要求和说明。 ko7-%+0|]
Ow&'sR'CX
很多时候,为了省时间,上来就去看程序,这样不仅不能省时间,还会走弯路、出错误。看看下面的两个例子吧! ?-6x]l=]
0I
ND9h.%
题例1:以下程序中函数f的功能是将n个字符串,按由大到小的顺序进行排序。 BR0p0%
szM=U$jKq
#include S92!jp/
6u]OXPA|
void f(char p[][10],int n) UdM5R
[
[7Kj$PB3
{略} q_m#BE;t
F" #3s=
main() uvK%d\d
0 S`b;f
{char p[][10]={"abc","aabdfg","abbd","dcdbe","cd"};int i; SJ|.% gn
\5L 4*
f(p,5); printf("%d\n",strlen(p[0])); } uhN(`E@
?RjKP3P
程序运行后的输出结果是 ~ @"Qm;}
"
b\uB
(A)6 (B)4 (C)5 (D)3 URzE+8m^
GT`<jzAi Q
(为了节省版面,把函数f的内容略去了。)看过文字说明,接着看主函数,就可以锁定这个字符串是“dcdbe”,而不用花时间去分析函数f。要注意的是:别把最长的一串当成最大的字符串噢,看上“aabdfg”可就错了,答 案应为C。 7_d#XKz@
Pt)}HF|u
题例2: 以下程序中给指针p分配三个double型动态内存单元,请填空。 1_E3DXe
b<8J ;u<
# include HI`A;G]
9QM"JEu@
main ( ) 0R!}}*Ee>q
cd%g]T)#1
{ double ?p; 2W-NCE%K)T
J$ih|nP
p=(double ?) malloc(【 】); L5N{ie_
bJMcI8`
p[0]=1.5;p[1]=2.5;p[2]=3.5; Q9'p3"yoE
k~EPVJh"
printf("%f%f%f\n",p[0],p[1],p[2]);} Y
Z2VP
o5G "J"vxe
如果上来就看程序,就会忽略“给指针p分配三个double型动态内存单元”,这里要求“三个”,如果大笔一挥写出了sizeof(double)可就太冤枉了,其实应该是3?sizeof(double)。 aZ:?(u]
!{ )AV/\D
第二类,把“赋值”看成了“等于” lL+^n~g
0 Ln5e.&
题例:有以下程序段 IF?B`TmZ
r#Oz0=0u
int k=0 F>-@LOqHy
)aA9z(x
while(k=1)k++; '!L1z45
BNm va
while 循环执行的次数是: 7;-i_&vws
_CwQ}n*
(A)无限次 (B)有语法错,不能执行 U=#ylQ
wdDHRW0Y
(C)一次也不执行 (D)执行1次 O)Dw<j)
R3!vS+5rR
此题如果理解为k等于1时循环才执行,那么“k++”不被执行,k的值就始终为0,这时就把C选上了。其实,while循环的条件是一个赋值表达式,答 案为A。 Ewsg&CCN
B91PlM.
第三类,表达式的值与变量的值 `Q^Sm`R
z7pXpy \
题例:有以下程序 e;u8G/
Q3{&'|}^2
int a=2; Ck a]F2,
`-YSFQ~O,
int f(int ?a) /g7?,/vnZ
o[ W3/
{return (?a)++;} _5`S)G{
~TR|Pv
main( ) }? '9L:
2/q=l?
{ int s=0; 'm? x2$u8
x#VUEu]8
{ int a=5; cW^)$>A
O;t?@!_
s+=f(&&a); \k-juF80
=0yJ2[R7Do
} yC*B OJS
w:+#,,rwzV
s+=f(&&a); ?bDae%>.d,
:Aiu!}\
printf("%d\n",s); F76h
g'7hc~=
} 执行后输出结果是() <5vB{)Tq
-{SiK
(A)10 (B)9 (C)7 (D)8 M:f=JuAx
80>!qG
答 案是C。 *%BI*p
~o5iCt;w
此题有两个要点,1是局部变量与全局变量的作用范围,2是,函数f(&&a)返回的是表达式 (?a)++的值,而不? a的值。 FQ1oqqr
z5'nS&x
第四类,把关系表达式有别于数学上的关系式 P;/wb/
WN1-J(x6
题例:有以下程序 !jnIXvT1qy
fG5} '8
main() oF^hq-xcP
)B4c;O4t
{ int a=5,b=4,c=3,d=2; rL"k-5>fd
vBnHG-5;P
if(a>b>c) ha~s<
I
BQg]$Tr?
printf("%d\n",d); YcZ4y@6"
W/Q%%)J
else if((c-1>=d)==1) |%;txD
>vy+U
printf("%d\n",d+1); XnOl*#P
qEz'l'%(
else TvwIro
HE'8
printf("%d\n",d+2); 5~0;R`D
+[9"M+4-
} /MtacR
giJyMd}x
执行后输出结果是 ( ) 6s2g +[
#ySx$WT;
(A)2 (B)3 D<6kAGE
"PtH
F`mo
(C)4 (D)编译时有错,无结果 vn0*KIrX
W7"sWaOhW
这道题的关键在(a>b>c),答 案容易判断为A,5大于4也大于3,就把整个表达式判断为真值,其实,a>b已为真值,1>c则成了假值,所以答 案为B。 5Oq ;V:7
hDsORh!i
第五类,字符串的拷贝 0yNlf-O
$g;xw?~#
拷成了同一个字符 ro@BmRMW
k0?6.[ku
题例:若有定义语句:char s[100],d[100]; int j=0, i=0;,且s中已赋字符串,请填空以实现字符串拷贝。(注:不得使用逗号表达式) a| cD{d
/d'u1FnA=
while(){ d[j]= 【 】;j++;} a-y5 \x
UkV] F]
d[j]=0; 4/|=0TC;
g2q=&eI"
这里容易只看到当前,忽略了还有其他字符,错填为s。答 案为s[i++]。