3)if语句
else是与最接近的if且没有else的相组合的。
4)条件表达式:
表达式1?
表达式2:
表达式3
注意是当非0时候是表达式2的数值,当为0是就是表达式2的数值。
考试口诀:
真前假后。
5)switch语句:
a)一定要注意有break和没有break的差别,书上(34页)的两个例子,没有break时候,只要有一个case匹配了,剩下的都要执行,有break则是直接跳出了swiche语句。
b)switch只可以和break一起用,不可以和continue用。
c)switch(x)x:
是整型常量,字符型常量,枚举型数据。
{case1:
….不可以是变量。
case2:
….
}
第四章
1)三种循环结构:
a)for();while();do-while()三种。
b)for循环当中必须是两个分号,千万不要忘记。
c)写程序的时候一定要注意,循环一定要有结束的条件,否则成了死循环。
d)do-while()循环的最后一个while();的分号一定不能够丢。
(当心上机改错),do-while循环是至少执行一次循环。
2)break和continue的差别
记忆方法:
break:
是打破的意思,(破了整个循环)所以看见break就退出真个一层循环。
continue:
是继续的意思,(继续循环运算),但是要结束本次循环,就是循环体内剩下的语句不再执行,跳到循环开始,然后判断循环条件,进行新一轮的循环。
3)嵌套循环
就是有循环里面还有循环,这种比较复杂,要一层一层一步一步耐心的计算,一般记住两层是处理二维数组的。
4)while((c=getchar())!
=’\n’)和while(c=getchar()!
=’\n’)的差别
先看a=3!
=2和(a=3)!
=2的区别:
(!
=号的级别高于=号所以第一个先计算3!
=2)第一个a的数值是得到的1;第二个a的数值是3。
考试注意点:
括号在这里的重要性。
第五章
函数:
是具有一定功能的一个程序块;是C语言的基本组成单位。
1)函数的参数,返回数值(示意图):
2)一定要注意参数之间的传递
实参和形参之间传数值,和传地址的差别。
(考试的重点)
传数值的话,形参的变化不会改变实参的变化。
传地址的话,形参的变化就会有可能改变实参的变化。
3)函数声明的考查:
一定要有:
函数名,函数的返回类型,函数的参数类型。
不一定要有:
形参的名称。
4)要求掌握的库函数:
sqrt()fabs()pow()sin()其中pow(a,b)是重点。
23是由pow(2,3)表示的。
第六章
指针变量的本质是用来放地址,而一般的变量是放数值的。
int*p中*p和p的差别:
*p可以当做变量来用;*的作用是取后面地址p里面的数值
p是当作地址来使用。
*p++和(*p)++的之间的差别:
改错题目中很重要
*p++是地址会变化。
(*p)++是数值会要变化。
三名主义:
(考试的重点)
数组名:
表示第一个元素的地址。
数组名不可以自加,他是地址常量名。
(考了很多次)
函数名:
表示该函数的入口地址。
字符串常量名:
表示第一个字符的地址。
考试重要的话语:
指针变量是存放地址的。
并且指向哪个就等价哪个,所有出现*p的地方都可以用它等价的代替。
例如:
inta=2,*p=&a;
*p=*p+2;
(由于*p指向变量a,所以指向哪个就等价哪个,这里*p等价于a,可以相当于是a=a+2)
指针变量两种初始化
方法一:
inta=2,*p=&a;(定义的同时初始化)
方法二:
inta=2,*p; (定义之后初始化)
p=&a;
第七章
1)一维数组的重要概念:
对a[10]这个数组的讨论。
1、a表示数组名,是第一个元素的地址,也就是元素a[10]的地址。
2、a是地址常量,所以只要出现a++,或者是a=a+2赋值的都是错误的。
3、a是一维数组名,所以它是列指针,也就是说a+1是跳一列。
对a[3][3]的讨论。
1、a表示数组名,是第一个元素的地址,也就是元素a[10]的地址。
2、a是地址常量,所以只要出现a++,或者是a=a+2赋值的都是错误的。
3、a是二维数组名,所以它是行指针,也就是说a+1是跳一行。
4、a[0]、a[1]、a[2]也都是地址常量,不可以对它进行赋值操作,同时它们都是列指针,a[0]+1,a[1]+1,a[2]+1都是跳一列。
5、注意a和a[0]、a[1]、a[2]是不同的,它们的基类型是不同的。
前者是一行元素,后三者是一列元素。
2)二维数组做题目的技巧:
如果有a[3][3]={1,2,3,4,5,6,7,8,9}这样的题目。
步骤一:
把他们写成:
第一列 第二列 第三列
a[0] 1 2 3->第一行
a[1]4 5 6 —>第二行
a[2]7 8 9 ->第三行
步骤二:
这样作题目间很简单:
*(a[0]+1)我们就知道是第一行的第一个元素往后面跳一列,那么这里就是a[0][1]元素,所以是1。
*(a[1]+2)我们就知道是第二行的第一个元素往后面跳二列。
那么这里就是a[1][2]元素,所以是6。
一定记住:
只要是二维数组的题目,一定是写成如上的格式,再去做题目,这样会比较简单。
3)数组的初始化,一维和二维的,一维可以不写,二维第二个一定要写
inta[]={1,2}合法。
inta[][4]={2,3,4}合法。
但inta[4][]={2,3,4}非法。
4)二维数组中的行指针
inta[1][2];
其中a现在就是一个行指针,a+1跳一行数组元素。
搭配(*)p[2]指针
a[0],a[1]现在就是一个列指针。
a[0]+1跳一个数组元素。
搭配*p[2]指针数组使用
5)还有记住脱衣服法则:
a[2]变成*(a+2)a[2][3]变成*(a+2)[3]再可以变成*(*(a+2)+3)
这个思想很重要!
其它考试重点
文件的复习方法:
把上课时候讲的文件这一章的题目要做一遍,一定要做,基本上考试的都会在练习当中。
1)字符串的strlen()和strcat()和strcmp()和strcpy()的使用方法一定要记住。
他们的参数都是地址。
其中strcat()和strcmp()有两个参数。
2)strlen和sizeof的区别也是考试的重点;
3)definef(x)(x*x)和definef(x)x*x之间的差别。
一定要好好的注意这写容易错的地方,替换的时候有括号和没有括号是很大的区别。
4)int*p;
p=(int*)malloc
(2);
p=(int*)malloc(sizeof(int));以上两个等价
当心填空题目,malloc的返回类型是void*
5)还有main(intargc,char**argv){}这种含有参数的题目,是很呆板的题目。
第一个参数是表示输入的字符串的数目,第二个参数是指向存放的字符串。
6)函数的递归调用一定要记得有结束的条件,并且要会算简单的递归题目。
要会作递归的题目
7)结构体和共用体以及链表要掌握最简单的。
typedef考的很多,而且一定要知道如何引用结构体中的各个变量,链表中如何填加和删除节点,以及何如构成一个简单的链表,一定记住链表中的节点是有两个域,一个放数值,一个放指针。
8)函数指针的用法(*f)()记住一个例子:
intadd(intx,inty)
{....}
main()
{int(*f)();
f=add;
}
赋值之后:
合法的调用形式为1、add(2,3);
2、f(2,3);
3、(*f)(2,3)
9)两种重要的数组长度:
chara[]={‘a’,’b’,’c’}; 数组长度为3,字符串长度不定。
sizeof(a)为3。
chara[5]={‘a’,’b’,’c’} 数组长度为5,字符串长度3。
sizeof(a)为5。
10)scanf和 gets的数据:
如果输入的是 goodgoodstudy!
那么scanf(“%s”,a);只会接收 good. 考点:
不可以接收空格。
gets(a);会接收 goodgoodstudy!
考点:
可以接收空格。
11)共用体的考查:
unionTT
{inta;
charch[2];}
考点一:
sizeof(structTT)=2;
考点二:
TT t1;t1=0x1234;
那么 ch[0]=0x34;ch[1]=0x12
12)“文件包含”的考查点:
no1.cno2.c
intadd(inta,intb)
{
returna+b;
}
#include”no2.c”
main()
{add(29,33);
…….
}
这里一个C语言程序是有两个文件组成,分别是no1.c,no2.c。
那么no1.c中最开始有个#include”no2.c”他表示把第二个文件的内容给包含过来,那么no1.c中调用add()函数的时候就可以了把数值传到no2.c中的被调用函数add()了。
一个文件必须要有main函数。
这句话错了。
例如:
no2.c就没有。
头文件一定是以.h结束的。
这句话错了。
例如:
no1.c中就是#include”no2.c”以.c结尾的。
第一章C语言基本知识
【考点1】C程序
用C语言编写的程序称为C语言源程序,源程序文件的后缀名为“.c”。
源程序经编译后生成后缀名为“.obj”的目标文件,再把目标文件与各种库函数连接起来,生成“.exe”可执行文件。
C语言有三种基本结构:
顺序结构、选择结构、循环结构。
【考点2】main函数
又称主函数,是C程序的入口。
main后面跟一对小括号和一对花括号,花括号括起来的部分称为main函数的函数体。
一个C程序从main函数开始执行,到main函数体执行完结束,而不论main函数在整个程序中的位置如何。
每一个程序有且仅有一个main函数,其他函数都是为main函数服务的。
【考点3】存储形式
计算机在电脑中保存数据是采用二进制形式,由0或1构成的二进制称为位(bit),八个位构成一个字节(Byte),1个Byte=8个bit。
二进制、八进制、十六进制转化为十进制采用乘法,十进制转化为二进制、八进制、十六进制采用除法。
数据的存放位置就是它的地址。
【考点4】注释
是对程序的说明,可出现在程序中任意合适的地方,注释从“/*”开始到最近一个“*/”结束,其间任何内容都不会被计算机执行,注释不可以嵌套。
【考点5】书写格式
每条语句的后面必须有一个分号,分号是语句的一部分。
一行内可写多条语句,一个语句可写在多行上。
【考点6】标识符
是标识名字的有效字符序列,可以理解为C程序中的单词。
标识符的命名规则是:
(1)标识符只能由字母、数字和下划线组成,字母区分大小写。
(2)标识符的第一个字符必须是字母或下划线,不能为数字。
C语言标识符分如下3类
(1)关键字。
它们在程序中有固定的含义,不能另作他用。
如int、for、switch等。
(2)预定义标识符。
预先定义并具有特定含义的标识符。
如define、include等。
(3)用户标识符。
用户根据需要定义的标识符,符合命名规则且不与关键字相同。
【考点7】常量与变量
常量是指在程序运行过程中,其值不能改变的量。
常量分为整型常量、实型常量、字符常量、字符串常量、符号常量5种。
在程序运行过程中其值可以改变的量称为变量。
C语言中没有字符串变量。
存放字符串使用字符数组。
【考点8】整型数据
整型常量有十进制、八进制、十六进制三种表示形式,没有二进制形式。
八进制整型常量加前导数字0,十六进制常量加前导0X,八进制常量中不会出现8。
整型变量可分为基本整型(int)、短整型(short)、长整型(long)、和无符号整型(unsigned)。
一个基本整型占4个字节。
其它类型的整型占用字节数和取值范围详见教材第9页。
【考点9】实型数据
实型数据有两种表示形式:
小数形式和指数形式。
掌握判定指数形式合法性。
口诀:
E前E后必有数,E后必须为整数。
实型变量分为单精度型(float)和双精度型(double),单精度型占四个字节。
【考点10】算术运算
算术运算符一共有+、—、*、/、%这五个。
求余运算要求运算对象只能为整型,除法运算符两边运算对象都为整型时,运算结果也为整型即舍掉小数部分。
【考点11】强制类型转换
将一个运算对象转换成指定类型,格式为(类型名)表达式,注意小括号位置。
【考点12】赋值
赋值运算符为“=”,不同于关系等于“==”。
赋值表达式格式为:
变量名=表达式,赋值运算符左边必须为变量,赋值运算是把赋值运算符右边表达式的值赋给左边变量。
复合赋值运算符是将算术运算符或位运算符与赋值运算符组合在一起组成的运算符,掌握复合赋值表达式转化为赋值表达式的方法。
如n+=100可转化为n=n+100。
【考点13】自加自减运算
自加运算符“++”与自减运算符“--”是单目运算符,运算对象必须是变量。
自增自减运算分前缀运算和后缀运算,它们所对应的表达式的值是有区别的,如j=i++;等价于j=i;i=i+1;而j=++i;等价于i=i+1;j=i;。
口诀:
加加在前先加后用,加加在后先用后加。
【考点14】逗号运算
逗号运算符运算优先级最低,可将多个表达式构成一个新的表达式。
第二章顺序结构
【考点1】运算符、表达式、语句
运算对象加运算符构成表达式,表达式加分号构成表达式语句,运算对象可以是表达式、常量、变量。
如赋值运算符加运算对象构成赋值表达式,赋值表达式加分号又可构成赋值语句。
【考点2】运算符的优先级和结合顺序
运算符按参加运算的对象数目可分为单目运算符、双目运算符和三目运算符。
初等运算符的优先级别最高,然后依次是单目运算符、算术运算符、关系运算符、逻辑运算符(除逻辑非!
)、条件运算符、赋值运算符、逗号运算符。
位运算符优先级介于算术运算符与逻辑运算符之间。
结合顺序大多为自左向右,而自右向左的有三个:
单目运算符、条件运算符和赋值运算符。
【考点3】printf函数
格式为:
printf(输出控制,输出列表)。
输出控制是用一对双引号括起来的,包含格式说明和原样信息。
输出列表包含若干输出项。
【考点4】printf函数中格式说明
%d对应整型,%f对应单精度实型,%c对应字符型,%o对应八进制无符号整型,%x对应无符号十六进制整型,%u对应无符号整型,%e对应指数型,%s对应字符串型。
可在%和格式字符之间加一个数来控制数据所占的宽度和小数位数。
【考点5】scanf函数
输入项要求带取地址符&。
当用键盘输入多个数据时,数据之间用分隔符。
分隔符包括空格符、制表符和回车符,但不包括逗号。
【考点】6如何交换两个变量
要使用中间变量,语句为:
t=x;x=y;x=t;。
第三章选择结构
【考点1】关系运算
C语言用非0表示逻辑真,用0表示逻辑假。
关系运算符有6个,分别是>,>=,<,<=,==,!
=,前四种优先级高于后两种。
关系表达式真时为1,假时为0。
注意a
【考点2】逻辑运算
逻辑运算符共有3个:
逻辑与(&&),逻辑或(||),逻辑非(!
)。
注意短路现象,例a++||b++,如果表达式a++的值非零,则表达式b++不再执行。
【考点3】if语句
可以单独出现,也可以与else匹配出现。
if语句可以嵌套,这时else总是与离它最近的且没有与else匹配的if匹配。
【考点4】条件运算
是唯一的三目运算符,格式为:
表达式1?
表达式2:
表达式3。
表达式1值为非0时,整个表达式值为表达式2的值,表达式1值为0时,整个表达式值为表达式3的值。
口诀:
真前假后
【考点5】switch语句
格式及执行过程详见教材P33,要注意每条case后有没有break语句的区别。
还要注意switch后小括号里面的表达式不能为实型,case后表达式不能有变量。
口诀:
switch表不为实,case表不为变。
第四章循环结构
【考点1】三种循环结构
三种循环结构分别为:
while,do-while,for,三种结构的格式及执行顺序详见教材第36、39、40页。
注意for循