干货 C语言编程

谈及C语言,我想凡是学过它的朋友都有这样一种感觉,那就是“让我欢喜让我忧。”欢喜的是,C语言功能非常强大、应用广泛,一旦掌握了后,你就可以理直气壮地对他人说“我是电脑高手!”,而且以后若是再自学其他语言就显得轻而易举了。忧虑的是,C语言犹如“少林武功”一般博大精深,太难学了。其实就小编认为C语言并非是晦涩难懂的,只要你能理清思路,掌握它的精髓,那么学习C语言是一件非常容易事。

谈及C语言,我想凡是学过它的朋友都有这样一种感觉,那就是“让我欢喜让我忧。”欢喜的是,C语言功能非常强大、应用广泛,一旦掌握了后,你就可以理直气壮地对他人说“我是电脑高手!”,而且以后若是再自学其他语言就显得轻而易举了。忧虑的是,C语言犹如“少林武功”一般博大精深,太难学了。其实就小编认为C语言并非是晦涩难懂的,只要你能理清思路,掌握它的精髓,那么学习C语言是一件非常容易事。

但是想很快掌握是不可能的,以大部分专业学习者的学习经验来看,刚入门学习一门计算机语言,教学书你至少要看三遍才能完全掌握的。出于现实的考虑现在教材看三遍基本上不太可能了。在此小编就给大家带上一点干货,希望大家在能够通过这门考试的同时喜欢上C语言。好的,废话不多说,下面分为三个大板块给大家简单介绍一下C语言及其应考策略。(知识的需要耐心感悟,如内容有出入,一切以教材为准)

一、C语言错例分析

C语言编译的程序对语法检查并不像其它高级语言那么严格,这就给编程人员留下“灵活的余地”,但还是由于这个灵活给程序的调试带来了许多不便,尤其对初学C语言的人来说,经常会出一些连自己都不知道错在哪里的错误。看着有错的程序,不知该如何改起,通过对C语言的学习,积累了一些C编程时常犯的错误,以供参考。

1、书写标识符时,忽略了大小写字母的区别。

main()

{

int a=5;

printf(“%d”,A);

}

编译程序把a和A认为是两个不同的变量名,而显示出错信息。C认为大写字母和小写字母是两个不同的字符。习惯上,符号常量名用大写,变量名用小写表示,以增加可读性。

2、忽略了变量的类型,进行了不合法的运算。

main()

{

float a,b;

printf(“%d”,a%b);

}

%是求余运算,得到a/b的整余数。整型变量a和b可以进行求余运算,而实型变量则不允许进行“求余”运算。

3、将字符常量与字符串常量混淆。

char c;

c=”a”;

在这里就混淆了字符常量与字符串常量,字符常量是由一对单引号括起来的单个字符,字符串常量是一对双引号括起来的字符序列。C规定以“\”作字符串结束标志,它是由系统自动加上的,所以字符串“a”实际上包含两个字符:‘a’和‘\0’,而把它赋给一个字符变量是不行的。

4、忽略了“=”与“==”的区别。

在许多高级语言中,用“=”符号作为关系运算符“等于”。如在BASIC程序中可以写

if (a=3) then …

但C语言中,“=”是赋值运算符,“==”是关系运算符。如:

if (a==3) a=b;

前者是进行比较,a是否和3相等,后者表示如果a和3相等,把b值赋给a。由于习惯问题,初学者往往会犯这样的错误。

5、忘记加分号。

分号是C语句中不可缺少的一部分,语句末尾必须有分号。

a=1

b=2

编译时,编译程序在“a=1”后面没发现分号,就把下一行“b=2”也作为上一行语句的一部分,这就会出现语法错误。改错时,有时在被指出有错的一行中未发现错误,就需要看一下上一行是否漏掉了分号。

{

z=x+y;

t=z/100;

printf(“%f”,t);

}

对于复合语句来说,最后一个语句中最后的分号不能忽略不写(这是和PASCAL不同的)。

6、多加分号。

对于一个复合语句,如:

{

z=x+y;

t=z/100;

printf(“%f”,t);

};

复合语句的花括号后不应再加分号,否则将会画蛇添足。又如:

if (a%3==0);

i++;

本是如果3整除a,则i加1。但由于if (a%3==0)后多加了分号,则if语句到此结束,程序将执行i++语句,不论3是否整除a,i都将自动加1。再如:

for (i=0;I

{

scanf(“%d”,&x);

printf(“%d”,x);

}

本意是先后输入5个数,每输入一个数后再将它输出。由于for()后多加了一个分号,使循环体变为空语句,此时只能输入一个数并输出它。

7、输入变量时忘记加地址运算符“&”。

int a,b;

scanf(“%d%d”,a,b);

这是不合法的。scanf函数的作用是:按照a、b在内存的地址将a、b的值存进去。“&a”指a在内存中的地址。

8、输入数据的方式与要求不符。

①scanf(“%d%d”,&a,&b);

输入时,不能用逗号作两个数据间的分隔符,如下面输入不合法:

3,4

输入数据时,在两个数据之间以一个或多个空格间隔,也可用回车键,跳格键tab。

②scanf(“%d,%d”,&a,&b);

C语言规定:如果在“格式控制”字符串中除了格式说明以外还有其它字符,则在输入数据时应输入与这些字符相同的字符。下面输入是合法的:

3,4

此时不用逗号而用空格或其它字符是不对的。

3 4 3:4

又如:

scanf(“a=%d,b=%d”,&a,&b);

输入应如以下形式:

a=3,b=4

9、输入字符的格式与要求不一致。

在用“%c”格式输入字符时,“空格字符”和“转义字符”都作为有效字符输入。

scanf(“%c%c%c”,&c1,&c2,&c3);

如输入a b c

字符“a”送给c1,字符“ ”送给c2,字符“b”送给c3,因为%c只要求读入一个字符,后面不需要用空格作为两个字符的间隔。

10、输入输出的数据类型与所用格式说明符不一致。

例如,a已定义为整型,b定义为实型

a=3;b=4.5;

printf(“%f%d\n”,a,b);

编译时不给出出错信息,但运行结果将与原意不符。这种错误尤其需要注意。

11、输入数据时,企图规定精度。

scanf(“%7.2f”,&a);

这样做是不合法的,输入数据时不能规定精度。

12.switch语句中漏写break语句。

例如:根据考试成绩的等级打印出百分制数段。

switch(grade)

{

case ‘A’:printf(“85~100\n”);

case ‘B’:printf(“70~84\n”);

case ‘C’:printf(“60~69\n”);

case ‘D’:printf(“

default:printf(“error\n”);

}

由于漏写了break语句,case只起标号的作用,而不起判断作用。因此,当grade值为A时,printf函数在执行完第一个语句后接着执行第二、三、四、五个printf函数语句。正确写法应在每个分支后再加上“break;”。例如

case ‘A’:printf(“85~100\n”);break;

13、忽视了while和do-while语句在细节上的区别。

(1)

main()

{

int a=0,I;

scanf(“%d”,&I);

while(I

printf(“%d”,a);

}

(2)

main()

{

int a=0,I;

scanf(“%d”,&I);

do

while(I

printf(“%d”,a);

}

可以看到,当输入I的值小于或等于10时,二者得到的结果相同。而当I>10时,二者结果就不同了。因为while循环是先判断后执行,而do- while循环是先执行后判断。对于大于10的数while循环一次也不执行循环体,而do-while语句则要执行一次循环体。

14、定义数组时误用变量。

int n;

scanf(“%d”,&n);

int a[n];

数组名后用方括号括起来的是常量表达式,可以包括常量和符号常量。即C不允许对数组的大小作动态定义。

15、在定义数组时,将定义的“元素个数”误认为是可使的最大下标值。

main()

{

static int

a[10]=;

printf(“%d”,a[10]);

}

C语言规定:定义时用a[10],表示a数组有10个元素。其下标值由0开始,所以数组元素a[10]是不存在的。

16、在不应加地址运算符&的位置加了地址运算符。

char str[20];

scanf(“%s”,&str);

C语言编译系统对数组名的处理是:数组名代表该数组的起始地址,且scanf函数中的输入项是字符数组名,不必要再加地址符&。应改为:

scanf(“%s”,str);

17、同时定义了形参和函数中的局部变量。

int max(x,y)

int x,y,z;

{

z=x>y?x:y;

return(z);

}

形参应该在函数体外定义,而局部变量应该在函数体内定义。应改为:

int max(x,y)

int x,y;

{

int z;

z=x>y?x:y;

return(z);

}

二、6大C语言基础方面知识整理

1、C语言程序的结构认识

用一个简单的c程序例子,介绍c语言的基本构成、格式、以及良好的书写风格,使小伙伴对c语言有个初步认识。

例1:计算两个整数之和的c程序:

#include

main()

{

int a,b,sum; /*定义变量a,b,sum为整型变量*/

a=20; /*把整数20赋值给整型变量a*/

b=15; /*把整数15赋值给整型变量b*/

sum=a+b; /*把两个数之和赋值给整型变量sum*/

printf(“a=%d,b=%d,sum=%d\n”,a,b,sum);

/*把计算结果输出到显示屏上*/

}

重点说明:

(1)、任何一个c语言程序都必须包括以下格式:

main()

{ }

这是c语言的基本结构,任何一个程序都必须包含这个结构。括号内可以不写任何内容,那么该程序将不执行任何结果。

(2)、main()----在c语言中称之为“主函数”,一个c程序有且仅有一个main函数,任何一个c程序总是从main函数开始执行,main函数后面的一对圆括号不能省略。

(3)、被大括号{ }括起来的内容称为main函数的函数体,这部分内容就是计算机要执行的内容。

(4)、在{ }里面每一句话后面都有一个分号(;),在c语言中,我们把以一个分号结尾的一句话叫做一个c语言的语句,分号是语句结束的标志。

(5)、printf(“a=%d,b=%d,

sum=%d\n”,a,b,sum); ----

通过执行这条c语言系统提供给我们直接使用的屏幕输出函数,用户即可看到运行结果,本程序运行后,将在显示器上显示如下结果:

a=20,b=15,sum=35

(6)、#include

注意:(1)以#号开头 (2)不以分号结尾

这一行没有分号,所以不是语句,在c语言中称之为命令行,或者叫做“预编译处理命令”。

(7)、程序中以 /*开头并且以*/结尾的部分表示程序的注释部分,注释可以添加在程序的任何位置,为了提高程序的可读性而添加,但计算机在执行主函数内容时完全忽略注释部分,换而言之就是计算机当做注释部分不存在于主函数中。

2、C程序的生成过程

C程序是先由源文件经编译生成目标文件,然后经过连接生成可执行文件。源程序的扩展名为 .c ,目标程序的扩展名为 .obj , 可执行程序的扩展名为 .exe 。

标识符

在编写程序时,必须为函数、变量等命名,这个名字称为标识符。C语言中标识符的命名规则如下:

标识符只能由字母、数字、下划线组成;

标识符的第一个字母必须是字母和下划线;

标识符区分大小写字母,如If和if是两个完全不同的标识符。

合法标识符如下:

A6, b_3 , _mn

非法的标识符如下:

ab#12 , 8m , tr3:4 , yes no

标识符不能与程序中具有特殊意义的关键字相同,不能与用户编制的函数名、C语言库函数相同,在程序中各种标识符尽量不要重复,以便区分。选择变量名和其他标识符时,应注意做到 “见名知义”。

3、常量

在程序运行中,其值不能被改变的量称为常量。常量有5种类型:整型常量、实型常量、字符常量、字符串常量和符号常量。

(1)、数值转换

数字的四种表现形式:

①:二进制:所有数字由0,1构成,逢二进一,二进制数中不会出现2.。

例:110101

②:八进制:以数字0(注意不是以字母O,o)开头,所有数字由0~7构成,逢八进一,八进制数中不会出现8。

例:0112,0123,077等

③:十进制:所有数字由0~9构成,逢十进一,十进制数中不会出现10。

例:0,12,-15等

④:十六进制:以0x或者0X(数字0加字母x)开头,所有数字由0~9,A~F(或者a~f)构成,逢十六进一(其中A、B、C、D、E、F分别代表10、11、12、13、14、15)

例:0x4A、0X14c7等

在计算机内部,数字均以二进制形式表示和存放,用户输入的普通十进制数字都要被计算机转换成二进制才能在计算机内部存储,同样计算机的运算结果也为二进制,一般要将其转换成十进制数再输出给用户阅读,这种转换通常由计算机自动实现。

(2)、整型常量

整型常量有3种形式:十进制整型常量、八进制整型常量和十六进制整型常量。

(注意:c语言中没有直接表示二进制的整型常量,在c语言源程序中不会出现二进制。)

书写方式如下:

十进制整型常量:123 , 0 ,-24 , 85L(长整型常量) 等

八进制整型常量:051 ,-026 ,0773 等

十六进制整型常量:0x55 , 0x1101 , 0x , 0x5AC0 , -0xFF。

其中L为长整型。

(3)、字符常量

字符常量的标志是一对单引号‘ ’,c语言中的字符常量有两类:

①由一对单引号括起来的一个字符,如‘a ’, ‘r’ ,‘#’。注意: ′a′ 和 ′A′ 是两个不同的字符常量。

②由一对单引号括起来,以反斜杠\开头,后跟若干数字或者字母,比如‘\n’,其中“\“是转义的意思,后面跟不同的字符表示不同的意思,这类字符常量叫转义字符。

4、变量

变量就是其值可以改变的量。变量要有变量名,在内存中占据一定的存储单元,存储单元里存放的是该变量的值。不同类型的变量其存储单元的大小不同,变量在使用前必须定义。

(1)、整型变量

整型变量分为4种:基本型(int)、短整型(short int 或short)、长整型(long int 或 long)和无符号型(unsigned int ,unsigned short,unsigned long)。

不同的编译系统对上述四种整型数据所占用的位数和数值范围有不同的规定。

类型说明符

说明:

单词signed来说明“有符号”(即有正负数之分),不写signed也隐含说明为有符号,unsigned用来说明“无符号”(只表示正数)。

(2)、实型变量

C语言中,实型变量分为单精度类型( float )和双精度类型( double )两种。如:

float a , b ;

double m ;

在vc中,float 型数据在内存中占4个字节(32位),double型数据占8个字节。单精度实数提供7位有效数字,双精度实数提供15~16位有效数字。实型常量不分float型和double型,一个实型常量可以赋给一个float 型或double型变量,但变量根据其类型截取实型常量中相应的有效数字。

注意:实型变量只能存放实型值,不能用整型变量存放实型值,也不能用实型变量存放整型值。

(3)、字符变量

字符变量用来存放字符常量,定义形式:

char 变量名;

其中关键字char定义字符型数据类型,占用一个字节的存储单元。

例:char cr1,cr2;

cr1= ‘A’ , cr2=‘B’ ;

将一个字符赋给一个字符变量时,并不是将该字符本身存储到内存中,而是将该字符对应的ASCII码存储到内存单元中。例如,字符 ′A′ 的ASCII码为65,在内存中的存放形式如下:01000001

由于在内存中字符以ASCII码存放,它的存储形式和整数的存储形式类似,所以C语言中字符型数据与整型数据之间可以通用,一个字符能用字符的形式输出,也能用整数的形式输出,字符数据也能进行算术运算,此时相当于对它们的ASCII码进行运算。

类型的自动转换和强制转换:

当同一表达式中各数据的类型不同时,编译程序会自动把它们转变成同一类型后再进行计算。

转换优先级为:

char

即左边级别“低“的类型向右边转换。

5、C运算符认识

C语言的运算符范围很广,可分为以下几类:

(1)、算术运算符:用于各类数值运算。包括加(+)、减(-)、乘(*)、除(/)、求余(%)、自增(++)、自减(--)共七种。

(2)、赋值运算符:用于赋值运算,分为简单赋值(=)、复合算术赋值(+=,-=,*=,/=,%=)和复合位运算赋值(&=,|=,^=,>>=,

(3)、逗号运算符:用于把若干表达式组合成一个表达式(,)。

(4)、关系运算符:用于比较运算。包括大于(>)、小于(=)、小于等于(

(5)、逻辑运算符:用于逻辑运算。包括与(&&)、或(||)、非(!)三种。

(6)、条件运算符:这是一个三目运算符,用于条件求值(?:)。

(7)、位操作运算符:参与运算的量,按二进制位进行运算。包括位与(&)、位或(|)、位非(~)、位异或(^)、左移(>)六种。

(8)、指针运算符:用于取内容(*)和取地址(&)二种运算。

(9)、求字节数运算符:用于计算数据类型所占的字节数(sizeof)。

(10)、特殊运算符:有括号(),下标[],成员(→,.)等几种。

另外,按参与运算的对象个数,C语言运算符可分为:单目运算符 (如 !)、双目运算符 (如+,- )和三目运算符 (如 ? : )。

6、关系运算符和关系表达式

(1)、C语言中的逻辑值

C语言中的逻辑值只有两个:真(true)和假(flase)。用非零代表真,用零代表假。因此,对于任意一个表达式,如果它的值为零,就代表一个假值,如果它的值为非零,就代表一个真值。只要值不是零,不管是正数,负数,整数,实数,都代表一个真值。例如-5的逻辑值为真。

(2)、逻辑表达式

“&&”和“||”的运算对象有两个,故它们都是双目运算符,而!的运算对象只有一个,因此它是单目运算符。逻辑运算举例如下:

①、a&&b: 当&&两边都为“真”时,表达式a&&b的值才是真。口诀:“一假必假”。

值得注意的是:在数学中,关系式0

②、a||b: 当||两边有一个为“真”时,表达式a||b的值就是真。口诀:“一真必真”。

③、!a: 表示取反,如果a为真,则!A为假,反之亦然。例如!-5的值就为0.

三、C语言期末复习策略

复习建议再看一次教材,实在没时间的“童鞋”可以看一下每个章节的典型例题,了解基本的知识结构,然后看一下章末复习或者是统一购买的小册子。小道消息,听说只要认真复习期末考试基本上不用担心哦~

得选择题者得“天下”啊~

大题的话程序修改题和程序填空题个人觉得算是比较好拿分,只要这两道题做对了基本及格就没问题了。做题的机巧就是你可以随便填但是要根据题目的要求直到运行后是对的为止,这样有无限次机会可以试,会C语言的一般最后填着填着就对了。第三道大题的话就比较难了,一般能拿分的就拿分,不能拿分的就算了,毕竟程序编写题难啊。不过也要看你抽中的题目难不难靠运气。

个人觉得技巧就是先做大题再做选择题。毕竟大题做好了选择题就不怕了,还可以有好多时间做。如果卡在选择题上又心里想着大题还没做那种心情真是煎熬啊……

编辑|孙 鹏

校对|朱玉龙、苏思思

责编|曹司帅

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180610B1KDKF00?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。

扫码关注云+社区

领取腾讯云代金券