《C语言指针详细讲解54726.ppt》由会员分享,可在线阅读,更多相关《C语言指针详细讲解54726.ppt(75页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、你现在所处的位置在:首页C语言教学幻灯片版第八章 指针1第八章 指针指针的概念指针变量指针与数组指针与函数返回指针值的函数你现在所处的位置在:首页C语言教学幻灯片版第八章 指针2前言C程序设计中使用指针可以:s使程序简洁、紧凑、高效s有效地表示复杂的数据结构s动态分配内存s得到多于一个的函数返回值你现在所处的位置在:首页C语言教学幻灯片版第八章 指针3变量与地址程序中:int i;float k;内存中每个字节有一个编号-地址.2000200120022005内存02003ik 编译或函数调用时为其分配内存单元变量是对程序中数据存储空间的抽象8.1 指针的概念你现在所处的位置在:首页C语言教学
2、幻灯片版第八章 指针4.2000200420062005整型变量i10变量i_pointer200120022003指针:一个变量的地址指针变量:专门存放变量地址的变量叫2000指针指针变量 变量的内容 变量的地址指针变量变量变量地址(指针)变量值指向地址存入指针变量指针与指针变量你现在所处的位置在:首页C语言教学幻灯片版第八章 指针5含义含义:取变量的地址单目运算符优先级:2结合性:自右向左含义:取指针所指向变量的内容单目运算符优先级:2结合性:自右向左两者关系:互为逆运算理解.2000200420062005整型变量i10变量i_pointer2001200220032000指针变量i_p
3、ointer-指针变量,它的内容是地址量*i_pointer-指针的目标变量,它的内容是数据&i_pointer-指针变量占用内存的地址200010i_pointer*i_pointer&i_pointerii_pointer&i&(*i_pointer)i *i_pointer *(&i)i_pointer =&i =&(*i_pointer)i =*i_pointer =*(&i)&与*运算符你现在所处的位置在:首页C语言教学幻灯片版第八章 指针6直接访问:按变量地址存取变量值间接访问:通过存放变量地址的变量去访问变量例 i=3;-直接访问指针变量.2000200420062005整型变量
4、i10变量i_pointer20012002200320003例 *i_pointer=20;-间接访问20直接访问与间接访问你现在所处的位置在:首页C语言教学幻灯片版第八章 指针7指针变量.2000200420062005整型变量i10变量i_pointer2001200220032000整型变量k例 k=i;-直接访问 k=*i_pointer;-间接访问10例 k=i;k=*i_pointer;例子图解你现在所处的位置在:首页C语言教学幻灯片版第八章 指针8指针变量与其所指向的变量之间的关系指针变量的定义一般形式:存储类型 数据类型 *指针名;3变量i2000i_pointer*i_po
5、interi*i_pointer&ii_pointeri=3;*i_pointer=33变量i2000i_pointer*i_pointeri*i_pointer&ii_pointeri=3;*i_pointer=3合法标识符指针变量本身的存储类型指针的目标变量的数据类型表示定义指针变量不是*运算符例 int*p1,*p2;float *q;static char *name;注意:1、int *p1,*p2;与 int *p1,p2;2、指针变量名是p1,p2,不是*p1,*p23、指针变量只能指向定义时所规定类型的变量4、指针变量定义后,变量值不确定,应用前必须先赋值8.2 指针变量你现在
6、所处的位置在:首页C语言教学幻灯片版第八章 指针9一般形式:存储类型 数据类型 *指针名=初始地址值;赋给指针变量,不是赋给目标变量例 int i;int *p=&i;变量必须已说明过类型应一致例 int *p=&i;int i;例 int i;int *p=&i;int *q=p;用已初始化指针变量作初值例 main()int i;static int *p=&i;.()不能用auto变量的地址去初始化static型指针指针变量的初始化你现在所处的位置在:首页C语言教学幻灯片版第八章 指针10例 main()int i=10;int *p;*p=i;printf(“%d”,*p);危险!例
7、main()int i=10,k;int *p;p=&k;*p=i;printf(“%d”,*p);.2000200420062005整型变量i10指针变量p200120022003随机指针变量必须先赋值,再使用你现在所处的位置在:首页C语言教学幻灯片版第八章 指针11零指针:(空指针)定义:指针变量值为零表示:int *p=0;p指向地址为0的单元,系统保证该单元不作它用表示指针变量值没有意义#define NULL 0int *p=NULL:p=NULL与未对p赋值不同用途:避免指针变量的非法引用在程序中常作为状态比较 例 int *p;.while(p!=NULL).void *类型指针
8、表示:void *p;使用时要进行强制类型转换例 char *p1;void *p2;p1=(char *)p2;p2=(void*)p1;表示不指定p是指向哪一种类型数据的指针变量零指针与空类型指针你现在所处的位置在:首页C语言教学幻灯片版第八章 指针12main()int*p1,*p2,*p,a,b;scanf(%d,%d,&a,&b);p1=&a;p2=&b;if(ab)p=p1;p1=p2;p2=p;printf(a=%d,b=%dn,a,b);printf(max=%d,min=%dn,*p1,*p2);运行结果:a=5,b=9 max=9,min=5.指针变量p1 指针变量p200
9、02008200220042006 指针变量p2 整型变量b 整型变量a5200692008200620082006例 输入两个数,并使其从大到小输出你现在所处的位置在:首页C语言教学幻灯片版第八章 指针13特点:共享内存,“双向”传递swap(int x,int y)int temp;temp=x;x=y;y=temp;main()int a,b;scanf(%d,%d,&a,&b);if(ab)swap(a,b);printf(n%d,%dn,a,b);例 将数从大到小输出.20002008200A2002200420065变量a 变量b(main)9 变量temp 变量y 变量x(swa
10、p)559 59COPY指针变量作为函数参数地址传递你现在所处的位置在:首页C语言教学幻灯片版第八章 指针14特点:共享内存,“双向”传递swap(int x,int y)int temp;temp=x;x=y;y=temp;main()int a,b;scanf(%d,%d,&a,&b);if(ab)swap(a,b);printf(n%d,%dn,a,b);例 将数从大到小输出值传递.20002008200A2002200420065变量a 变量b(main)9运行结果:5,9指针变量作为函数参数地址传递你现在所处的位置在:首页C语言教学幻灯片版第八章 指针15swap(int *p1,i
11、nt *p2)int p;p=*p1;*p1=*p2;*p2=p;main()int a,b;int*pointer_1,*pointer_2;scanf(%d,%d,&a,&b);pointer_1=&a;pointer_2=&b;if(ab)swap(pointer_1,pointer_2);printf(n%d,%dn,a,b);.20002008200A200220042006200C200E2010.59整型变量a 整型变量b(main)指针pointer_1指针pointer_220002002(swap)指针p1指针p2整型p5920002002COPY5例 将数从大到小输出你现
12、在所处的位置在:首页C语言教学幻灯片版第八章 指针16swap(int *p1,int *p2)int p;p=*p1;*p1=*p2;*p2=p;main()int a,b;int*pointer_1,*pointer_2;scanf(%d,%d,&a,&b);pointer_1=&a;pointer_2=&b;if(ab)swap(pointer_1,pointer_2);printf(n%d,%dn,a,b);.20002008200A200220042006200C200E2010.59整型变量a 整型变量b(main)指针pointer_1指针pointer_22000200259运
13、行结果:9,5地址传递例 将数从大到小输出(1)你现在所处的位置在:首页C语言教学幻灯片版第八章 指针17swap(int*p1,int*p2)int*p;*p=*p1;*p1=*p2;*p2=*p;main()int a,b;int*pointer_1,*pointer_2;scanf(%d,%d,&a,&b);pointer_1=&a;pointer_2=&b;if(ab)swap(pointer_1,pointer_2);printf(n%d,%dn,a,b);运行结果:9,9编译警告!结果不对!int x;int *p=&x;x;.20002008200A200220042006200
14、C200E2010.59整型变量a 整型变量b(main)指针pointer_1指针pointer_2200020029920002002COPY(swap)指针p1指针p2指针p*假设2000指针变量在使用前必须赋值!例 将数从大到小输出(2)你现在所处的位置在:首页C语言教学幻灯片版第八章 指针18/*ch9_32.c*/swap(int x,int y)int t;t=x;x=y;y=t;main()int a,b;int*pointer_1,*pointer_2;scanf(%d,%d,&a,&b);pointer_1=&a;pointer_2=&b;if(ab)swap(*point
15、er_1,*pointer_2);printf(n%d,%dn,a,b);运行结果:5,9值传递.20002008200A200220042006200C200E2010.59整型a 整型b(main)pointer_1pointer_2200020029COPY(swap)整型x整型b整型t555 9例 将数从大到小输出(3)你现在所处的位置在:首页C语言教学幻灯片版第八章 指针19运行结果:5,9swap(int*p1,int*p2)int*p;p=p1;p1=p2;p2=p;main()int a,b;int*pointer_1,*pointer_2;scanf(%d,%d,&a,&b)
16、;pointer_1=&a;pointer_2=&b;if(ab)swap(pointer_1,pointer_2);printf(%d,%d,*pointer_1,*pointer_2);.20002008200A200220042006200C200E2010.59整型a 整型b(main)pointer_1pointer_22000200220002002COPY(swap)指针p1指针p2指针p*2000地址传递20002002例 将数从大到小输出(4)你现在所处的位置在:首页C语言教学幻灯片版第八章 指针20指向数组元素的指针变量例 int array10;int *p;p=&arr
17、ay0;/p=array;或 int *p=&array0;或 int *p=array;array0array1array2array3array9.整型指针p&array0p数组名是表示数组首地址的地址常量8.3 指针与数组你现在所处的位置在:首页C语言教学幻灯片版第八章 指针21指针变量的赋值运算p=&a;(将变量a地址p)p=array;(将数组array首地址p)p=&arrayi;(将数组元素地址p)p1=p2;(指针变量p2值p1)不能把一个整数p,也不能把p的值整型变量如 int i,*p;p=1000;()i=p;()指针变量与其指向的变量具有相同数据类型指针的运算你现在所处
18、的位置在:首页C语言教学幻灯片版第八章 指针22pi p id (i为整型数,d为p指向的变量所占字节数)p+,p-,p+i,p-i,p+=i,p-=i等若p1与p2指向同一数组,p1-p2=两指针间元素个数(p1-p2)/dp1+p2 无意义例 p指向float数,则 p+1 p+1 4例 p指向int型数组,且p=&a0;则p+1 指向a1例 int a10;int *p=&a2;p+;*p=1;例 int a10;int*p1=&a2;int*p2=&a5;则:p2-p1=3;a0a1a2a3a4a5a6a7a8a9a数组pp+1,a+1p+i,a+ip+9,a+91指针的算术运算:你现
19、在所处的位置在:首页C语言教学幻灯片版第八章 指针23若p1和p2指向同一数组,则p1p2 表示p1指的元素在后p1=p2 表示p1与p2指向同一元素若p1与p2不指向同一数组,比较无意义p=NULL或p!=NULL指针变量的关系运算你现在所处的位置在:首页C语言教学幻灯片版第八章 指针24a0a1a2a3a9.aa+9a+1a+2地址元素下标法a0a1a2a9a0a1a2a3a9.pp+9p+1p+2地址元素指针法*p*(p+1)*(p+2)*(p+9)变址运算符ai *(a+i)ai pi *(p+i)*(a+i)*a*(a+1)*(a+2)*(a+9)p0p1p2p9你现在所处的位置在:
20、首页C语言教学幻灯片版第八章 指针25a0a1a2a3a4main()int a5,*pa,i;for(i=0;i5;i+)ai=i+1;pa=a;for(i=0;i5;i+)printf(*(pa+%d):%dn,i,*(pa+i);for(i=0;i5;i+)printf(*(a+%d):%dn,i,*(a+i);for(i=0;i5;i+)printf(pa%d:%dn,i,pai);for(i=0;i5;i+)printf(a%d:%dn,i,ai);12345pa例 数组元素的引用方法你现在所处的位置在:首页C语言教学幻灯片版第八章 指针26例 int a=1,2,3,4,5,6,7
21、,8,9,10,*p=a,i;数组元素地址的正确表示:(A)&(a+1)(B)a+(C)&p (D)&pi数组名是地址常量p+,p-()a+,a-()a+1,*(a+2)()你现在所处的位置在:首页C语言教学幻灯片版第八章 指针27例 void main()int a=5,8,7,6,2,7,3;int y,*p=&a1;y=(*-p)+;printf(“%d ”,y);printf(“%d”,a0);输出:5 6pp58762730123456a6例 注意指针变量的运算你现在所处的位置在:首页C语言教学幻灯片版第八章 指针28main()int i,*p,a7;p=a;for(i=0;i7;
22、i+)scanf(%d,p+);printf(n);for(i=0;i7;i+,p+)printf(%d,*p);p=a;pp58762730123456apppppp指针变量可以指到数组后的内存单元例 注意指针的当前值你现在所处的位置在:首页C语言教学幻灯片版第八章 指针29数组名作函数参数,是地址传递数组名作函数参数,实参与形参的对应关系实参形参数组名指针变量数组名指针变量数组名数组名指针变量指针变量数组名作函数参数你现在所处的位置在:首页C语言教学幻灯片版第八章 指针30ij 3 7 9 11 0 6 7 5 4 20 1 2 3 4 5 6 7 8 9ijijijji117605947
23、23实参与形参均用数组void inv(int x,int n)int t,i,j,m=(n-1)/2;for(i=0;i=m;i+)j=n-1-i;t=xi;xi=xj;xj=t;main()int i,a10=3,7,9,11,0,6,7,5,4,2;inv(a,10);printf(The array has been reverted:n);for(i=0;i10;i+)printf(%d,ai);printf(n);m=4例 将数组a中的n个整数按相反顺序存放(1)你现在所处的位置在:首页C语言教学幻灯片版第八章 指针31void inv(int *x,int n)int t,*p,
24、*i,*j,m=(n-1)/2;i=x;j=x+n-1;p=x+m;for(;i=p;i+,j-)t=*i;*i=*j;*j=t;main()int i,a10=3,7,9,11,0,6,7,5,4,2;inv(a,10);printf(The array has been reverted:n);for(i=0;i10;i+)printf(%d,ai);printf(n);实参用数组,形参用指针变量37911067542a0a1a2a3a4a5a6a7a8a9xp=x+ma数组60711594723ijijijjiji例 将数组a中的n个整数按相反顺序存放(2)你现在所处的位置在:首页C语言
25、教学幻灯片版第八章 指针32void inv(int*x,int n)int t,*i,*j,*p,m=(n-1)/2;i=x;j=x+n-1;p=x+m;for(;i=p;i+,j-)t=*i;*i=*j;*j=t;main()int i,a10,*p=a;for(i=0;i10;i+,p+)scanf(%d,p);p=a;inv(p,10);printf(The array has been reverted:n);for(p=a;pa+10;p+)printf(%d,*p);实参与形参均用指针变量例 将数组a中的n个整数按相反顺序存放(3)你现在所处的位置在:首页C语言教学幻灯片版第八章
26、 指针33void inv(int x,int n)int t,i,j,m=(n-1)/2;for(i=0;i=m;i+)j=n-1-i;t=xi;xi=xj;xj=t;main()int i,a10,*p=a;for(i=0;i10;i+,p+)scanf(%d,p);p=a;inv(p,10);printf(The array has been reverted:n);for(p=arr;parr+10;p+)printf(%d,*p);实参用指针变量,形参用数组例 将数组a中的n个整数按相反顺序存放(4)你现在所处的位置在:首页C语言教学幻灯片版第八章 指针34int *p 与 int
27、q10 数组名是指针(地址)常量p=q;p+i 是qi的地址数组元素的表示方法:下标法和指针法,即若p=q,则 pi qi *(p+i)*(q+i)形参数组实质上是指针变量,即int q int*q在定义指针变量(不是形参)时,不能把int *p 写成int p;系统只给p分配能保存一个指针值的内存区(一般2字节);而给q分配2*10字节的内存区一级指针变量与一维数组的关系你现在所处的位置在:首页C语言教学幻灯片版第八章 指针35二维数组的地址对于一维数组:(1)数组名array表示数组的首地址,即array0的地址;(2)数组名array是地址常量(3)array+i是元素arrayi的地址
28、(4)arrayi *(array+i)arrayint array10;指针与二维数组你现在所处的位置在:首页C语言教学幻灯片版第八章 指针36对于二维数组:(1)a是数组名,包含三个元素 a0,a1,a2(2)每个元素ai 又是一个一维 数组,包含4个 元素aa+1a+2*(*(a+0)+1)*(a0+1)int a34;a0a1a2200020082016200020022008201020162018a00a01a10a11a20a21a02a03a12a13a22a23基类型a0+1a1+1a2+1*(a+0)+1*(a+1)+1*(a+2)+1行指针与列指针(1)你现在所处的位置在
29、:首页C语言教学幻灯片版第八章 指针37s对二维数组 int a34,有sa-二维数组的首地址,即第0行的首地址sa+i-第i行的首地址sai *(a+i)-第i行第0列的元素地址sai+j *(a+i)+j-第i行第j列的元素地址s*(ai+j)*(*(a+i)+j)aija+i=&ai=ai=*(a+i)=&ai0,值相等,含义不同a+i&ai,表示第i行首地址,指向行ai *(a+i)&ai0,表示第i行第0列元素地址,指向列int a34;a0a1a2200020082016200020022008201020162018a00a01a10a11a20a21a02a03a12a13a2
30、2a23aa+1a+2行指针与列指针(2)你现在所处的位置在:首页C语言教学幻灯片版第八章 指针38int a34;a00a01a10a11a20a21a02a03a12a13a22a23二维数组元素表示形式:(1)a12(2)*(a1+2)(3)*(*(a+1)+2)(4)*(&a00+1*4+2)地址表示:(1)a+1 (2)&a10(3)a1(4)*(a+1)(5)(int *)(a+1)行指针列指针地址表示:(1)&a12(2)a1+2(3)*(a+1)+2(4)&a00+1*4+2行指针与列指针(3)你现在所处的位置在:首页C语言教学幻灯片版第八章 指针39表示形式含义地址a二维数组
31、名,数组首地址a0,*(a+0),*a第0行第0列元素地址a+1第1行首地址a1,*(a+1)第1行第0列元素地址a1+2,*(a+1)+2,&a12第1行第2列元素地址*(a1+2),*(*(a+1)+2),a12第1行第2列元素值2000200020082008201213表格说明你现在所处的位置在:首页C语言教学幻灯片版第八章 指针40s指向二维数组元素的指针变量例 指向二维数组元素的指针变量main()static int a34=1,3,5,7,9,11,13,15,17,19,21,23;int*p;for(p=a0;pa0+12;p+)if(p-a0)%4=0)printf(n)
32、;printf(%4d ,*p);p=*a;p=&a00;p=*(a+0);p=a;p=*a;p=&a00;p=(int*)a;p=a;int a34;a00a01a10a11a20a21a02a03a12a13a22a23p二维数组的指针变量你现在所处的位置在:首页C语言教学幻灯片版第八章 指针41s定义形式:数据类型 (*指针名)一维数组维数;例 int (*p)4;()不能少int(*p)4与int*p4不同p的值是一维数组的首地址,p是行指针可让p指向二维数组某一行 如 int a34,(*p)4=a;int a34;a00a01a10a11a20a21a02a03a12a13a22a
33、23aa+1a+2pp+1p+2p0+1或*p+1p1+2或*(p+1)+2*(*p+1)或(*p)1*(*(p+1)+2)一维数组指针变量维数和二维数组列数必须相同指向一维数组的指针变量你现在所处的位置在:首页C语言教学幻灯片版第八章 指针42main()int a34=1,2,3,4,3,4,5,6,5,6,7,8;int i;int(*p)4=a,*q=a0;for(i=0;i3;i+)if(i=0)(*p)i+i/2=*q+1;else p+,+q;for(i=0;i3;i+)printf(%d,aii);printf(%d,%dn,*(int*)p),*q);运行结果:2,4,7,5
34、,3123434565678pq2pqpq例 二维数组与指针运算你现在所处的位置在:首页C语言教学幻灯片版第八章 指针43s用指向变量的指针变量s用指向一维数组的指针变量s用二维数组名实参形参数组名int x4指针变量int (*q)4数组名int x4指针变量int(*q)4数组名a数组名a指针变量p1指针变量p1若int a34;int (*p1)4=a;int *p2=a0;指针变量p2指针变量int *q二维数组的指针作函数参数你现在所处的位置在:首页C语言教学幻灯片版第八章 指针44main()void average(float *p,int n);void search(floa
35、t (*p)4,int n);float score34=65,67,79,60,80,87,90,81,90,99,100,98;average(*score,12);search(score,2);void average(float*p,int n)float *p_end,sum=0,aver;p_end=p+n-1;for(;p=p_end;p+)sum=sum+(*p);aver=sum/n;printf(average=%5.2fn,aver);void search(float (*p)4,int n)int i;printf(No.%d :n,n);for(i=0;iy?x:
36、y);return(xy?x:y);min(int x,int y)printf(“min=”);printf(“min=”);return(xy?x:y);return(xy?x:y);add(int x,int y)printf(“sum=”);printf(“sum=”);return(x+y);return(x+y);用函数指针变量作函数参数你现在所处的位置在:首页C语言教学幻灯片版第八章 指针52函数定义形式:类型标识符 *函数名(参数表);例 int *f(int x,int y)例 指针函数实现:有若干学生成绩,要求输入学生序号后,能输出其全部成绩main()float scor
37、e4=60,70,80,90,56,89,67,88,34,78,90,66;float *search(float (*pointer)4,int n),*p;int i,m;printf(Enter the number of student:);scanf(%d,&m);printf(The scores of No.%d are:n,m);p=search(score,m);for(i=0;i*y)return x;elsereturn y;main()int a=2,b=3;int*p;p=f1(&a,&b);printf(%dn,*p);.20002008200A200220042
38、00623 指针变量y 指针变量x(f1)20022000COPY变量a 变量b(main)指针变量p*例 写一个函数,求两个int型变量中居于较大值的变量的地址(1)你现在所处的位置在:首页C语言教学幻灯片版第八章 指针54.20002008200A2002200420062变量a 变量b(main)3 指针变量p*2002int*f3(int*x,int*y)if(*x*y)return x;elsereturn y;main()int a=2,b=3;int*p;p=f1(&a,&b);printf(%dn,*p);例 写一个函数,求两个int型变量中居于较大值的变量的地址(2)你现在所
39、处的位置在:首页C语言教学幻灯片版第八章 指针55int*f3(int x,int y)if(xy)return&x;elsereturn&y;main()int a=2,b=3;int*p;p=f3(a,b);printf(%dn,*p);.20002008200A20022004200623 变量y 变量x(f3)32COPY变量a 变量b(main)指针变量p*例 写一个函数,求两个int型变量中居于较大值的变量的地址(3)你现在所处的位置在:首页C语言教学幻灯片版第八章 指针56不能返回形参或局部变量的地址作函数返回值.20002008200A2002200420062变量a 变量b(
40、main)3 指针变量p*200Aint*f3(int x,int y)if(xy)return&x;elsereturn&y;main()int a=2,b=3;int*p;p=f3(a,b);printf(%dn,*p);例 写一个函数,求两个int型变量中居于较大值的变量的地址(4)你现在所处的位置在:首页C语言教学幻灯片版第八章 指针57 用于处理二维数组或多个字符串指针数组定义:数组中的元素为指针变量定义形式:存储类型 数据类型*数组名数组长度说明;例 int *p4;指针所指向变量的数据类型指针本身的存储类型区分int *p4与int (*p)4指针数组赋值与初始化赋值:main(
41、)int b23,*pb2;pb0=b0;pb1=b1;.int *pb2pb0pb1int b23123246初始化:main()int b23,*pb=b0,b1;.int *pb2pb0pb1int b23123246 指针数组和多级指针你现在所处的位置在:首页C语言教学幻灯片版第八章 指针58L i s p 0F o r t r a n 0B a s i c 0p0p1p2p30赋值:main()char a=Fortran;char b=Lisp;char c=Basic;char*p4;p0=a;p1=b;p2=c;p3=NULL;.或:main()char*p4;p0=Fortr
42、an;p1=Lisp;p2=Basic;p3=NULL;.初始化:main()char*p=Fortran,Lisp,Basic,NULL;.L i s p 0F o r t r a n 0B a s i c 0p0p1p2p30指针数组赋值与初始化你现在所处的位置在:首页C语言教学幻灯片版第八章 指针59 char name59=“gain”,“much”,“stronger”,“point”,“bye”;char*name5=“gain”,“much”,“stronger”,“point”,“bye”;g a i n 0s t r o n g e r 0p o i n t 0m u c h
43、 0name0name1name2name3name4b y e 0g a i n 0s t r o n g e r 0p o i n t 0m u c h 0b y e 0二维数组存储空间固定字符指针数组相当于可变列长的二维数组分配内存单元=数组维数*2+各字符串长度指针数组元素的作用相当于二维数组的行名但指针数组中元素是指针变量二维数组的行名是地址常量二维数组与指针数组区别:你现在所处的位置在:首页C语言教学幻灯片版第八章 指针60main()int b23,*pb2;int i,j;for(i=0;i2;i+)for(j=0;j3;j+)bij=(i+1)*(j+1);pb0=b0;pb
44、1=b1;for(i=0;i2;i+)for(j=0;j3;j+,pbi+)printf(b%d%d:%2dn,i,j,*pbi);int *pb2pb0pb1int b23b00 *pb0b01 *(pb0+1)b02 *(pb0+2)b10 *pb1b11 *(pb1+1)b12 *(pb1+2)123246例 用指针数组处理二维数组你现在所处的位置在:首页C语言教学幻灯片版第八章 指针61main()void sort(char *name,int n),print(char *name,int n);char*name=Follow me,BASIC,Great Wall,FORTRA
45、N,Computer;int n=5;sort(name,n);print(name,n);void sort(char*name,int n)char*temp;int i,j,k;for(i=0;in-1;i+)k=i;for(j=i+1;j0)k=j;if(k!=i)temp=namei;namei=namek;namek=temp;name0name1name2name3name4nameGreat WallFORTRANComputerFollow meBASICkjkjjji=0例 对字符串排序(简单选择排序)图解1你现在所处的位置在:首页C语言教学幻灯片版第八章 指针62main
46、()void sort(char *name,int n),print(char *name,int n);char*name=Follow me,BASIC,Great Wall,FORTRAN,Computer;int n=5;sort(name,n);print(name,n);void sort(char*name,int n)char*temp;int i,j,k;for(i=0;in-1;i+)k=i;for(j=i+1;j0)k=j;if(k!=i)temp=namei;namei=namek;namek=temp;name0name1name2name3name4nameGre
47、at WallFORTRANComputerFollow meBASICkkjjji=1k例 对字符串排序(简单选择排序)图解2你现在所处的位置在:首页C语言教学幻灯片版第八章 指针63main()void sort(char *name,int n),print(char *name,int n);char*name=Follow me,BASIC,Great Wall,FORTRAN,Computer;int n=5;sort(name,n);print(name,n);void sort(char*name,int n)char*temp;int i,j,k;for(i=0;in-1;i
48、+)k=i;for(j=i+1;j0)k=j;if(k!=i)temp=namei;namei=namek;namek=temp;name0name1name2name3name4nameGreat WallFORTRANComputerFollow meBASICkkjji=2例 对字符串排序(简单选择排序)图解3你现在所处的位置在:首页C语言教学幻灯片版第八章 指针64main()void sort(char *name,int n),print(char *name,int n);char*name=Follow me,BASIC,Great Wall,FORTRAN,Computer;
49、int n=5;sort(name,n);print(name,n);void sort(char*name,int n)char*temp;int i,j,k;for(i=0;in-1;i+)k=i;for(j=i+1;j0)k=j;if(k!=i)temp=namei;namei=namek;namek=temp;name0name1name2name3name4nameGreat WallFORTRANComputerFollow meBASICkkji=3例 对字符串排序(简单选择排序)图解4你现在所处的位置在:首页C语言教学幻灯片版第八章 指针65main()void sort(ch
50、ar *name,int n),print(char *name,int n);char*name=Follow me,BASIC,Great Wall,FORTRAN,Computer;int n=5;sort(name,n);print(name,n);void sort(char*name,int n)char*temp;int i,j,k;for(i=0;in-1;i+)k=i;for(j=i+1;j0)k=j;if(k!=i)temp=namei;namei=namek;namek=temp;name0name1name2name3name4nameGreat WallFORTRAN