- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C语言程序设计基础第10章指针进阶.docx
C语言程序设计基础第10章 指针进阶
刘新国
1
本章要点
指针数组和指向指针的指针
指针作为函数的返回值
指向函数的指针
指向结构的指针
对链表数据结构
2
指针数组
char * color[5] = { “red”, “blue”,
“yellow”, “green”, “black”
};
3
11.1.2 指针数组的概念
首先,它是一个数组
其次,它的元素是指针
定义格式
类型名 *数组名[长度];
遵循数组的定义语法
只不过,元素类型为指针类型
4
指针数组
char * color[5] = { “red”, “blue”,
“yellow”, “green”, “black”
};
for( i=0; i5; i++ )
printf(%d-th color = %s\n, i, color[i]);
5
指针数组
char * color[5] = { “red”, “blue”,
“yellow”, “green”, “black”
};
char *t = color[0];
color[0] = color[4];
color[4] = t;
对一般数组的操作,适合于指针数组
定义,初始化,元素的使用,赋值
6
指向指针的指针(二级指针)
int a = 10;
int *p = a;
int **pp = p;
定义语法格式
类型名 **指针变量名;
7
*p
*pp
**pp
指向指针的指针(二级指针)
二级(多级)指针都是指针
可以应用指针的所有操作
定义、初始化、赋值
和数组结合使用
特殊的是:它指向一个指针
8
三级指针和多级指针
int a = 10, *p= a, **pp = p
三级指针
int ***p3 = pp;
四级指针
int ****p4 = p3;
9
指针数组和二级指针
char * color[5] = { “red”, “blue”,
“yellow”, “green”, “black”
};
数组名color是一指针,
指向首元素color[0]。
char **pc = color;
char str[20];
scanf(“%s”, str);
for ( i=0; i5; i++ )
if( strcmp(str, *(pc+i))==0 ) break;
if(i5) printf(“color id = %d\n”,i);
else printf(“not found\n”);
10
pc[i]
11.1.4 指针数组与二维数组
char ccolor[][7] = { “red”, “blue”,
“yellow”, “green”, “black”
};
char * pcolor[5] = { “red”, “blue”,
“yellow”, “green”, “black”
};
ccolor
11.1.4 指针数组与二维数组
pcolor[i]指向一个字符串,即该字符串首个字符
pcolor[i] + k 则指向该字符串的第k个字符
所以 *(pcolor[i] + k)就是该字符,也可以写作
pcolor[i][k]
注意:pcolor不是二维数组
ccolor
[例11-4] 字符串排序
#define SWAP(a,b,t) t=a,a=b,b=t
void fsort(char* color[], int n)
{
int k, j;
char * tmp;
for( k=1; kn; k++ ) for( j=0; jn-k; j++ )
if( strcmp(color[j],color[j+1])0 )
SWAP (color[j], color[j+1], tmp);
}
主程序
void main()
{
char *pcolor[5]={“red”, blue”,
“yellow”, “green”, “black”};
int k;
fsort(pcolor,5);
for( k=0; k5; k++ )
printf(“%s”, pcolor[k]);
}
[例11-6] 藏头诗解密
void main()
{
char *poem[4]={“一叶轻舟向东流”,“帆梢轻握杨柳手”,
“风纤碧波微起舞”,“顺水任从雅客悠”};
char mean[10];
int i;
for( i=0; i4; i++ )
{
mean[2
您可能关注的文档
最近下载
- 储能电池项目工程组织与管理计划.docx VIP
- flotherm学习教程v8.1升级练习题zoomin.pdf VIP
- 五年(21-25)高考真题分类汇编专题06文言文阅读(双文本)(全国通用)(含解析).docx VIP
- CNAS-GL004-2018 标准物质_标准样品的使用指南 (2019-2-20第一次修订).pdf VIP
- 三年级上册10总复习(共43张PPT).pptx VIP
- 预防艾梅乙母婴传播理论考试试题及参考答案.docx VIP
- 中考名著导读《红星照耀中国》专项练习10试题.doc VIP
- 缠绕成型工艺及设备课件.ppt VIP
- 每月食品安全调度会议纪要.docx VIP
- 规范文件T∕CCSAS 004-2019 危化品企业设备完整性管理导则.pdf VIP
文档评论(0)