C语言基础知识重点和难点.pdf





《C语言基础知识重点和难点.pdf》由会员分享,可在线阅读,更多相关《C语言基础知识重点和难点.pdf(19页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、C语言基础知识重点和难点一、数组1.一维数组的定义与初始化1)不能在方括号中用变量来表示元素的个数,但是可以是符号常数或常量表达式。例如:#define FD 5main()(int a3+2,b7+FD;)是合法的。但是卜述说明方式是错误的。main()(int n=5;int an;)2)C 语言对数组的初始化赋值还有以下几点规定:(1)可以只给部分元素赋初值。当 中值的个数少于元素个数时,只给前面部分元素赋值。例如:int a10=0,1,2,3,4;表示只给a0 a 4 5 个元素赋值,而后5 个元素自动赋0 值。(2)只能给元素逐个赋值,不能给数组整体赋值。例如给十个元素全部赋1值,
2、只能写为:int a10=l,1,1,1,1,1,1,1,1,1);而不能写为:int a10=l;(3)如给全部元素赋值,则在数组说明中,可以不给出数组元素的个数。例如:int a5=l,2,3,4,5;可写为:int a=l,2,3,4,5;2.一维数组元素的引用1)在 c 语言中只能逐个地使用下标变量,而不能一次引用整个数组。例如,输出有10个元素的数组必须使用循环语句逐个输出各下标变量:for(i=0;i 8 0,7 5,9 2 ,6 1,6 5,7 1 ,5 9,6 3,7 0 ,8 5,8 7,9 0 ,7 6,7 7,8 5 ;2)按行连续赋值可写为:i nt a 5 3 =8
3、0,7 5,9 2,6 1,6 5,7 1,5 9,6 3,7 0,8 5,8 7,9 0,7 6,7 7,8 5);对于二维数组初始化赋值还有以下说明:1)可以只对部分元素赋初值,未赋初值的元素自动取。值。例如:i nt a 3 3 =,;是对每一行的第一列元素赋值,未赋值的元素取0值。赋值后各元素的值为:1 0 02 0 03 0 0i nt a 3 =0,1 ,0,0,2 ,;赋值后的元素值为:0 1 00 0 23 0 02)如对全部元素赋初值,则第一维的长度可以不给出。例如:i nt a 3 3 =1,2,3,4,5,6,7,8,9 ;可以写为:i nt a口=1,2,3,4,5,6
4、,7,8,9 ;例1:以下不能正确定义二维数组的选项是 D。A、B、C、D,intintintinta 2 2 );a 2 =1,2,3,4 ;a 2 2 =1 ,2,3 a 2 =(l,2 ,3,4 )可以只对部分元素赋初值,未赋初值的元素自动取0值如对全部元素赋初值,则第一维的长度可以不给出,但第二维的长度必须给出。5.二维数组元素的引用和一维数组一样,一定要注意下标不越界。例1:若有定义int a23;以下选项中对a数组元素正确引用的是.A)a2!1C)a03B)a23D)a12!1注意,a数组的下标范围为a 0 到所以A、B.C均错误。C语言中,数组下标可以是表达式,并且,tr ue是
5、1,f a lse是0,所以选项D实际上是a 6.字符数组的初始化1)字符数组也允许在定义时作初始化赋值。例 如:c h a r c 1 0 =lc l p ,r ,。,g ,r ,;赋值后各元素的值为:数 组C /0 的 值 为、1c l的 值 为,。2 的 值 为 加,c 的 值 为T。4 的值为0,c 5 的 值 为 gfc 6 的值为c 的 值 为 a,/8 的值为(1 1,其 中c 9 未赋值,由 的 值 为 p,系统 自 动 赋 予。值。当对全体元素赋初值时也可以省去长度说明。例如:c ha r c L=c,p,r,o,g,r,a,m J;这 时C数组的长度自动定为9。在C语言中没
6、有专门的字符串变量,通常用一个字符数组来存放一个字符串。前面介绍字符串常量时,已说明字符串总是以 0作为串的结束符。因此当把一个字符串存入一个数组时.,也把结束符 0存入数组,并以此作为该字符串是否结束的标志。有了 0标志后,就不必再用字符数组的长度来判断字符串的长度了。2)C语言允许用字符串的方式对数组作初始化赋值。例 如:c ha r c L J =c ,p,r,o,g,r,a,m);可写为:c ha r c =/C p ro g ra m ;或去掉。写为:c ha r c =C p ro g ra m”;用字符串方式赋值比用字符逐个赋值要多占一个字节,用于存放字符串结束标志 0。上面的数
7、组c 在内存中的当际产放情为:|C o|g|r|a|m|6、0 是 由 C编译系统自动加二的。由于采用了、0 标志,所以在用字符串赋初值时一般无须指定数组的长度,而由系统自行处理。7.字符串处理函数用于输入输出的字符串函数,在使用前应包含头文件S td i o.h,使用其它字符串函数则应包含头文件stri n g j。I)输出函数p uts2)输入函数g e ts:g e ts读入字符串时,可以读入其中的空格,直到回车。而用sc a n f 读入字符串时,遇到空格即停止。3)连接函数strc a t:格式为strc a t(字符数组名1,字符数组名2),一定注意,字符数组1一定要足够大,否则将
8、越界。4)拷贝函数strc p y:格式为strc p y(字符数组名1,字符数组名2)。注意,字符数组赋值,不能用等于号,而要用strc p y函数5)比较函数strc m p:格式为strc m p(字符数组名1,字符数组名2)。注意,字符数组的比较不能用大于、小于号比较。测字符串长度函数strl e n:测字符串的实际长度(不含字符串结束标志、0,)并作为函数返回值。-7 W,一、函数1.形式参数和实际参数函数的形参和实参具有以下特点:1)形参变量只有在被调用时才分配内存单元,在调用结束时,即刻释放所分配的内存单元。因此,形参只有在函数内部有效。函数调用结束返回主调函数后则不能再使用该形
9、参变量。2)实参可以是常量、变量、表达式、函数等,无论实参是何种类型的量,在进行函数调用时,它们都必须具有确定的值,以便把这些值传送给形参。因此应预先用赋值,输入等办法使实参获得确定值。3)实参和形参在数量上,类型上,顺序上应严格一致,否则会发生类型不匹配”的错误。4)函数调用中发生的数据传送是单向的。即只能把实参的值传送给形参,而不能把形参的值反向地传送给实参。因此在函数调用过程中,形参的值发生改变,而实参中的值不会变化。a 2 b 3 a 团 b 回XE J *国 y周下例可以说明这个问题。int s (int n)(int i;for(i=n-l;i=l;i)n=n+i;pr int f
10、(n二%d n,n);)main()(int n;pr int f(inpu t nu mber n);s canf(%d ,&n);s(n);pr int f(n二d n,n);2.数组作为函数参数i)数组元素作函数实参数组元素就是下标变量,它与普通变量并无区别。因此它作为函数实参使用与普通变量是完全相同的,在发生函数调用时,把作为实参的数组元素的值传送给形参,实现单向的值传送。2)数组名作为函数参数数组名作函数参数时所进行的传送只是地址的传送,也就是说把实参数组的首地址赋予形参数组名。形参数组名取得该首地址之后,也就等于有了实在的数组。实际上是形参数组和实参数组为同数组,共同拥有一段内存空
11、间。a0 J all a2 a3 a4 a5 a6 a7 J a8 J a9 24681 0 1 21 4 1 61 8 2 0起始地址2 0 0 0b0 bl b2 b3 b4 b5 b6 b7 b8 b9 上图说明了这种情形。图中设a 为实参数组,类型为整型。a 占有以2 0 0 0 为首地址的一块内存区。b 为形参数组名。当发生函数调用时,进行地址传送,把实参数组a 的首地址传送给形参数组名b,于是b 也取得该地址2 0 0 0。于是a,b 两数组共同占有以2 0 0 0 为首地址的一段连续内存单元。从图中还可以看出a 和 b 下标相同的元素实际上也占相同的两个内存单元(整型数组每个元素
12、占二字节)。例如 a0 和 b0 都占用2 0 0 0 和 2 0 0 1 单元,当然a0 等于b 0 h 类推则有ai等于bi。例 1:判别一个整数数组中各元素的值,若大于0则输出该值,若小于等于0则输出0 值。编程如下:v oid nz p(int a5)(int i;pr int f(z/nv alu es of ar r ay aar e:n);for(i=0;i 5;i+)(if(ai 0)ai=0;pr int f(组d ”,ai);)main()int b5,i;pr int f(ninpu t 5 nu mber s:nz/);for(i=0;i 5;i+)s canf(绘d”
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言 基础知识 重点 难点

限制150内