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,是个算术表达式
合法,同样是算术表达式
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](123->第一行
a[1](456—>第二行
a[2](789->第三行
步骤二:
这样作题目间很简单:
*(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.考点:
不可以接收空格。
gets(a);会接收goodgoodstudy!
考点:
可以接收空格。
14)数组中放数组一定要看懂:
inta[8]={1,2,3,4,4,3,2,2};
intb[5]={0};
b[a[3]]++这个写法要看懂,结果要知道是什么?
b[4]++,本身是0,运行完后,b[4]为1了。
15)字符串的赋值
C语言中没有字符串变量,所以用数组和指针存放字符串:
1、charch[10]={“abcdefgh”};对
2、charch[10]=“abcdefgh”;对
3、charch[10]={‘a’,’b’,’c’,’d’,’e’,’f’,’g’,’h’};对4、char*p=“abcdefgh”;对
5、char*p;对
p=“abcdefgh”;
6、charch[10];错了!
数组名不可以赋值!
ch=“abcdefgh”;
7、char*p={“abcdefgh”};错了!
不能够出现大括号!
16)字符串赋值的函数背诵:
一定要背诵,当心笔试填空题目。
把s指针中的字符串复制到t指针中的方法
1、while((*t=*s)!
=null){s++;t++;}统统版本
2、while(*t=*s){s++;t++;}简单版本
3、while(*t++=*s++);高级版本