C语言程序设计(第3版)何钦铭 颜 晖 第11章 指针进阶.docVIP

C语言程序设计(第3版)何钦铭 颜 晖 第11章 指针进阶.doc

  1. 1、本文档共18页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C语言程序设计(第3版)何钦铭 颜 晖 第11章 指针进阶

第11章 指针进阶 【练习11-1】如何理解指针数组,它与指针、数组有何关系?为何可以用二级指针数组进行操作? 解答: 指针数组——存放指针的一个数组。 指针数组名也是指向常量二级指针,因为指针数组名总是指向数组的第一个元素。 【练习11-2】用指针数组处理多个字符串有何优势?可以直接输入多个字符串给为初始化的指针数组吗?为什么? 解答: C语言中字符串的地址是按顺序存放的,用指针指向字符串的首地址,然后取出这个地址里面的值,然后指针加一,取出里面的值,这样就能输出整个字符串了。用指针数组可以接收多个字符串,对这些字符串的操作可以做到相互隔离,一个指针数组的元素作为一个指针对应一个字符串。 【练习11-3】参考例11-3,使用二级指针操作改写例11-4中的程序A。 解答: #includestdio.h #includestring.h void fsort(char **ch,int n); int main(void) { int i; char *pcolor[]={red,blue,yellow,green,black}; char **ch; ch=pcolor; fsort(ch,5); for(i=0;i5;i++) printf(%s ,*(ch+i)); return 0; } void fsort(char **ch,int n) { int k,j; char *temp; for(k=1;kn;k++) for(j=0;jn-k;j++) if(strcmp(*(ch+j),*(ch+j+1))0){ temp=*(ch+j); *(ch+j)=*(ch+j+1); *(ch+j+1)=temp; } } 【练习11-4】改写例11-8中的函数match(),要求返回字符串s中最后一个字符ch的位置(地址)。 解答: #includestdio.h char *match(char *s,char ch); int main (void) { char ch,str[80],*p=NULL; printf(Please Input the string:\n); scanf(%s,str); getchar(); ch=getchar(); if((p=match(str,ch))!=NULL) printf(%s\n,p); else printf(Not Found\n); return 0; } char *match(char *s,char ch) { char *k=NULL; while(*s!=\0){ if(*s==ch) k=s; s++; } return k; } 【练习11-5】前面章节中介绍的指针变量都可以进行算数运算,请思考:指向函数的指针变量可以进行算术运算吗? 解答: 函数指针变量不能进行算术运算,这是与数组指针变量不同的。数组指针变量加减一个整数可使指针移动指向后面或前面的数组元素,而函数指针的移动是毫无意义的。?? 【练习11-6】运行例11-10,试执行程序中个函数的功能,观察结果。 解答: 主函数包含选择链表新建、插入、删除和遍历的功能,而新建链表函数则是用链表的方式建立一整套有关学生的信息,插入操作函数则是可以在链表其中添加新的学生信息,删除操作函数则是可以在链表中删除要求删除的学生信息,最后的遍历操作函数则是显示所有的学生信息。 【练习11-7】改写例11-10中的函数DelectDoc(),要求删除链表中成绩小于60分的学生结点。 解答: struct stud_node* DeleteDoc(struct stud_node *head,int score) { struct stud_node *ptr1,*ptr2; /*要被删除结点为表头结点*/ while(head!=NULLhead-score==score){ ptr2=head; head=head-next; free(ptr2); } if(head==NULL) return NULL; /*要被删除结点为非表头结点*/ ptr1=head; ptr2=head-next; while(pt

文档评论(0)

zsmfjy + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档