if(a%i==0)printf(“不就是质数”);
printf(“就是质数!
”);
}
9、一定要注意参数之间得传递
实参与形参之间传数值,与传地址得差别。
(考试得重点)
传数值得话,形参得变化不会改变实参得变化。
传地址得话,形参得变化就会有可能改变实参得变化。
第六章
指针变量得本质就是用来放地址,而一般得变量就是放数值得。
1、int*p中*p与p得差别:
简单说*p就是数值,p就是地址!
*p可以当做变量来用;*得作用就是取后面地址p里面得数值
p就是当作地址来使用。
可以用在scanf函数中:
scanf(“%d”,p);
2、*p++与(*p)++得之间得差别:
改错题目中很重要!
考试超级重点
*p++就是地址会变化。
口诀:
取当前值,然后再移动地址!
(*p)++就是数值会要变化。
口诀:
取当前值,然后再使数值增加1。
例题:
int*p,a[]={1,3,5,7,9};
p=a;
请问*p++与(*p)++得数值分别为多少?
*p++:
这个本身得数值为1。
由于就是地址会增加一,所以指针指向数值3了。
(*p)++这个本身得数值为1。
由于有个++表示数值会增加,指针不移动,但数值1由于自加了一次变成了2。
3、二级指针:
*p:
一级指针:
存放变量得地址。
**q:
二级指针:
存放一级指针得地址。
常考题目:
intx=7;
int*p=&x,**q=p;
问您:
*p为多少?
*q为多少?
**q为多少?
7p7
再问您:
**q=&x得写法可以吗?
不可以,因为二级指针只能存放一级指针得地址。
4、三名主义:
(考试得重点)
数组名:
表示第一个元素得地址。
数组名不可以自加,她就是地址常量名。
(考了很多次)
函数名:
表示该函数得入口地址。
字符串常量名:
表示第一个字符得地址。
8、函数返回值就是地址,一定注意这个*号(上机考试重点)
int*fun(int*a,int*b)可以发现函数前面有个*,这个就说明函数运算结果就是地址
{if(*a>*b)returna;returna可以知道返回得就是a地址。
elsereturnb;
}
main()
{intx=7,y=8,*max;
max=fun(&x,&y);由于fun(&x,&y)得运算结果就是地址,所以用max来接收。
printf(“maxis%d”,*max);
}
9、考试重要得话语:
指针变量就是存放地址得。
并且指向哪个就等价哪个,所有出现*p得地方都可以用它等价得代替。
例如:
inta=2,*p=&a;
*p=*p+2;
(由于*p指向变量a,所以指向哪个就等价哪个,这里*p等价于a,可以相当于就是a=a+2)
第七章
数组:
存放得类型就是一致得。
多个数组元素得地址就是连续得。
1、一维数组得初始化:
inta[5]={1,2,3,4,5};合法
inta[5]={1,2,3,};合法
inta[]={1,2,3,4,5};合法,常考,后面决定前面得大小!
inta[5]={1,2,3,4,5,6};不合法,赋值得个数多余数组得个数了
2、一维数组得定义;
inta[5];注意这个地方有一个重要考点,定义时数组得个数不就是变量一定就是常量。
inta[5]合法,最正常得数组
inta[1+1]合法,个数就是常量2,就是个算术表达式
inta[1/2+4]合法,同样就是算术表达式
intx=5,inta[x];不合法,因为个数就是x,就是个变量,非法得,
defineP5inta[P]合法,define后得得P就是符号常量,只就是长得像变量
3、二维数组得初始化
inta[2][3]={1,2,3,4,5,6};合法,很标准得二维得赋值。
inta[2][3]={1,2,3,4,5,};合法,后面一个默认为0。
inta[2][3]={{1,2,3,}{4,5,6}};合法,每行三个。
inta[2][3]={{1,2,}{3,4,5}};合法,第一行最后一个默认为0。
inta[2][3]={1,2,3,4,5,6,7};不合法,赋值得个数多余数组得个数了。
inta[][3]={1,2,3,4,5,6};不合法,不可以缺省行得个数。
inta[2][]={1,2,3,4,5,6};合法,可以缺省列得个数。
补充:
1)一维数组得重要概念:
对a[10]这个数组得讨论。
1、a表示数组名,就是第一个元素得地址,也就就是元素a[0]得地址。
(等价于&a)
2、a就是地址常量,所以只要出现a++,或者就是a=a+2赋值得都就是错误得。
3、a就是一维数组名,所以它就是列指针,也就就是说a+1就是跳一列。
对a[3][3]得讨论。
1、a表示数组名,就是第一个元素得地址,也就就是元素a[0][0]得地址。
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(4);
p=(int*)malloc(sizeof(int));以上两个等价
当心填空题目,malloc得返回类型就是void*
6)函数得递归调用一定要记得有结束得条件,并且要会算简单得递归题目。
要会作递归得题目
7)结构体与共用体以及链表要掌握最简单得。
typedef考得很多,而且一定要知道如何引用结构体中得各个变量,链表中如何填加与删除节点,以及何如构成一个简单得链表,一定记住链表中得节点就是有两个域,一个放数值,一个放指针。
9)两种重要得数组长度:
chara[]={‘a’,’b’,’c’}; 数组长度为3,字符串长度不定。
sizeof(a)为3。
chara[5]={‘a’,’b’,’c’} 数组长度为5,字符串长度3。
sizeof(a)为5。
String=a,b,c字符串长度为四,包括终止符’0’、
10)scanf与 gets得数据:
如果输入得就是 goodgoodstudy!
那么scanf(“%s”,a);只会接收 good、 考点:
不可以接收空