- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第9章 指针进阶 学习目标 1.掌握指针数组的定义及其应用,了解二级指针的基本概念; 2. 理解二维数组的指针和指向二维数组的指针变量; 3. 了解指向函数的指针,理解指针型函数; 4. 初步了解内存的动态分配和动态回收; 5. 初步掌握单向链表的建立与访问、在单向链表中插入、删除结点等算法。 9.1 指针数组 9.1.1 指针数组的概念 指针数组:一个数组的每个元素均为指针类型 形式: 数据类型 *数组名[数组长度]; int *pa[3]; char *pname[5]= {JiangSu,ShanDong,ZheJiang,GuangXi,AnHui}; 9.1.2 指向指针的指针变量 指向指针的指针变量:一个指针变量中存放的是另一个指针变量的地址 形式: 数据类型 **指针变量名; int **p; int x=5,*q=x; int **p; p=q; #include stdio.h void main() { int a=10,*b,**c; b=a; c=b; printf(%d,%d,%d\n,a,*b,**c); *b=20; /* 通过b间接访问a */ printf(%d,%d,%d\n,a,*b,**c); **c=30; /* 通过c间接访问a */ printf(%d,%d,%d\n,a,*b,**c); } 运行结果: 10,10,10 20,20,20 30,30,30 9.1.3 指针数组应用举例 编程将若干字符串按字母顺序由小到大排序后输出。 #include stdio.h #include string.h #define N 5 /* 字符串个数 */ void sort(char **name,int n); void print(char *name[],int n); void main() { char *pname[N]={JiangSu,ShanDong,ZheJiang,GuangXi,AnHui}; printf(before sorted:\n); print(pname,N); /* 排序前输出各字符串 */ sort(pname,N); /* 排序 */ printf(after sorted:\n); print(pname,N); /* 排序后输出各字符串 */ } void sort(char *name[],int n) { char *pt; int i,j,k; for(i=0;in-1;i++) /* 选择排序算法 */ { k=i; for(j=i+1;jn;j++) if(strcmp(name[k],name[j])0) k=j; if(k!=i) { pt=name[i]; name[i]=name[k]; name[k]=pt; } } } void print(char **name,int n) { int i; for(i=0;in;i++) printf(%s\n,name[i]); /* 或 printf(%s\n,*(name+i)); */ } 9.2 二维数组的指针和 指向二维数组的指针变量 9.2.1 二维数组的行地址和列地址 一、二维数组的行地址 int s[3][4]; 由于行地址代表某一行(这一行可以看成是一个一维数组)的地址,而不是某一个元素的地址,故行地址是一个二级指针。 例如,s是第0行,即s[0](s[0]可看作是s[0][0]、s[0][1]、s[0][2]、s[0][3]四个元素组成的一维数组的数组名)的地址,s+1表示下一行的地址,即s[1]的地址。 二、二维数组的列地址 一维数组名代表数组首元素的地址 s[0]代表一维数组s[0]中第0列元素的地址(s[0][0]) s[1]代表一维数组s[1]中第0列元素的地址(s[1][0])s[2]代表一维数组s[2]中第0列元素的地址(s[2][0]) s[0]+0、s[0]+1、s[0]+2、s[0]+3分别是s[0][0]、s[0][1]、s[0][2]、s[0][3]
文档评论(0)