等级考试(笔试)虽然知识面比较广,但不是很深,基础部分考的是你日常操作的能力,程序设计多数是考你的细心。辛辛苦苦准备了大半年,又经过2个小时的考场之战,交卷之后还很“自美”,成绩单上的“不及格”让你一时不敢相信自己的眼睛。 t[^$F,
:KLXrr
当对着答 案细细“品味”时,你会N次的感叹……原来“罪魁祸首”是“不细心”。 yYG<tUG;
}Z!D?(
综观这四年来的考题,对容易出错的典型题例作了汇总和分析,也好给以后参加二级C考试的朋友增加点免疫力吧。本文将分三次刊登。 TktH28tK
OZ[ YB
第一类,审题不清 FKa";f"
;a:H-iC
1.审题时的一字之差。 +&EXTZ@o
y>^a~}Zq
一定要搞清题意,题目让我们选择的是“正确”还是“不正确”的;“能”还是“不能”的;本来要求选出一个错误的答 案,但题目中没有“错误”字样,而是说 “……请选出不正确的一项”,一不小心你就可能会把选项中最前面一个“正确”的选为答 案,因“正确”的有三个选项,当然觉得很容易,就这样,“错误”轻易地从你的笔尖溜走了。 'Uok<;
OmYVJt_
2.不注意文字部分的要求和说明。 r~4uIUE{
MY&Jdmga
很多时候,为了省时间,上来就去看程序,这样不仅不能省时间,还会走弯路、出错误。看看下面的两个例子吧! n<I{x^!
UtZ,q!sg
题例1:以下程序中函数f的功能是将n个字符串,按由大到小的顺序进行排序。 %`Re{%1;
w0pMH p'Y
#include NxT"A)u
JAPr[O&
void f(char p[][10],int n) qNp1<QO0
9Em#Ela
{略} K1B9t{T
<xOv8IQ|
main() v9*m0|T0M
&p0e)o~Ux
{char p[][10]={"abc","aabdfg","abbd","dcdbe","cd"};int i; vF$i"^;tJ;
ZL MH~cc
f(p,5); printf("%d\n",strlen(p[0])); } A'WR!*Yt
z6>@9+V-&
程序运行后的输出结果是 c OYDN[k
D #ddx
(A)6 (B)4 (C)5 (D)3 d0cL9&~qW
NFK`,
(为了节省版面,把函数f的内容略去了。)看过文字说明,接着看主函数,就可以锁定这个字符串是“dcdbe”,而不用花时间去分析函数f。要注意的是:别把最长的一串当成最大的字符串噢,看上“aabdfg”可就错了,答 案应为C。 XYE|=Tr]
yV30x9i!2
题例2: 以下程序中给指针p分配三个double型动态内存单元,请填空。 jmok]-pC
FR&`R
# include s27IeF3
NkE0S`Xf
main ( ) JzHG5nmB
[}RoZB&I
{ double ?p; 1J@Iekat
FMfpjuHk
p=(double ?) malloc(【 】); e|~MJu+1
Ucj?$=
p[0]=1.5;p[1]=2.5;p[2]=3.5; ^)VwxH:s
7*/{m K)
printf("%f%f%f\n",p[0],p[1],p[2]);} ]BQYVx/
D28`?B9(
如果上来就看程序,就会忽略“给指针p分配三个double型动态内存单元”,这里要求“三个”,如果大笔一挥写出了sizeof(double)可就太冤枉了,其实应该是3?sizeof(double)。 2hE(h
?GhyVXS y.
第二类,把“赋值”看成了“等于” $Y$9]G":
&hCbXs=
题例:有以下程序段 >yIJ8IDF
*Ak .KBg
int k=0 +^)v"@,VP
P T"}2sR)
while(k=1)k++; _KT!OYH
jYsAL=oh,*
while 循环执行的次数是: {4"V)9o-1>
'sNZFB#
(A)无限次 (B)有语法错,不能执行 |(7}0]BP0
OWd'z1Yl
(C)一次也不执行 (D)执行1次 8;PkuJR_]
,Q`qnn&
此题如果理解为k等于1时循环才执行,那么“k++”不被执行,k的值就始终为0,这时就把C选上了。其实,while循环的条件是一个赋值表达式,答 案为A。 Bq0 \T
0,
UZZJtQt
第三类,表达式的值与变量的值 X/!_>@`7?
O&`.R|v
题例:有以下程序 "gM^o
b7Y g~Lw
int a=2; ${Z0@G+
}5 o?7}?
int f(int ?a) pYO =pL^Q
MvVpp;bd
{return (?a)++;} 0X$mT:=9
^?z%f_ri
main( ) Cj5mM[:s
O5\r%&$xd
{ int s=0; b@:OlZ~%
Io6/Fv>!
{ int a=5; %36x'Dn?
yMs!6c*
s+=f(&&a); :_{8amO
6&3,fSP
} =:W2NN'
DA=!AK>
s+=f(&&a); $KHm5*;nd
)U^=`* 7
printf("%d\n",s); Et>#&Nw8
3? {AGJ1
} 执行后输出结果是() -(VJ,)8t2
.Po"qoGy
(A)10 (B)9 (C)7 (D)8 0^;2
:=QX ^*
答 案是C。 P<<$o-a"
.RQra+up
此题有两个要点,1是局部变量与全局变量的作用范围,2是,函数f(&&a)返回的是表达式 (?a)++的值,而不? a的值。 +z
>)'#
8`=?_zF
第四类,把关系表达式有别于数学上的关系式 %idBR7?`g
>A#5` $i
题例:有以下程序 b0P3S!E
dBWny&
main() Z9{~t
A=|XlP$6
{ int a=5,b=4,c=3,d=2; _\!]MV
MJn-] E
if(a>b>c)
tm1=
+ikSa8)*i
printf("%d\n",d); ?HEqv$n
$ {yct
else if((c-1>=d)==1) fHt \KP
PK\Z Rl
printf("%d\n",d+1); X1o",,N^M
sqkWQ`Ur
else m*0YMS>Y |
dab]>% M
printf("%d\n",d+2); V&mkS
WP<L9A
} {UNH?2
K.tNV{OL
执行后输出结果是 ( ) wmVmGa
R
qpQ;,8X-"
(A)2 (B)3 $H:!3-/
y:G%p3h)[
(C)4 (D)编译时有错,无结果 {QG.> lB
F>;Wbk&[|
这道题的关键在(a>b>c),答 案容易判断为A,5大于4也大于3,就把整个表达式判断为真值,其实,a>b已为真值,1>c则成了假值,所以答 案为B。 V"Q\7,_k.
-FeXG#{)
第五类,字符串的拷贝 A#U! KX
#~0Nk6*u
拷成了同一个字符 *PmZqe
p1N}2]e
题例:若有定义语句:char s[100],d[100]; int j=0, i=0;,且s中已赋字符串,请填空以实现字符串拷贝。(注:不得使用逗号表达式) |r9<aVlK
9>RkFV
while(){ d[j]= 【 】;j++;} +VwQ=[y]
y^2#;0W
d[j]=0; z?/_b
?Uql30A
这里容易只看到当前,忽略了还有其他字符,错填为s。答 案为s[i++]。