- 1、本文档共14页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
ch07数组和指针数组
6.25整理名字表。编写程序,输入任意顺序的名字表,将其按字典顺序排序并输出。 要求:分别用二维数组、指针数组指向二维数组、指针数组动态分配内存实现。 参考答案1:用二维数组实现 #includestdio.h #includestring.h #define M 6 #define N 20 void initial_string(char arr_str[M][N]); //初始化数组 void sort_string(char arr_str[M][N]); //主元排序 void out_string(char arr_str[M][N]); //输出 void main() { char name[M][N]; //二维数组:用于保存输入的M个名字 initial_string(name); sort_string(name); printf(排序后:\n); out_string(name); } void initial_string(char arr_str[M][N]) { printf(请输入%d个名字序列:\n,M); for(int i=0;iM;i++) scanf(%s,arr_str[i] ); } void out_string(char arr_str[M][N])//输出 { int j; for(j=0;jM;j++) printf(%s\n,arr_str[j]); } void sort_string( char arr_str[M][N] ) { char temp[N]; int i,j,k; for(i=0;iM-1;i++) { k=i; for(j=i+1;jM;j++) if(strcmp(arr_str[k],arr_str[j])0) k=j; strcpy(temp,arr_str[i]); strcpy(arr_str[i],arr_str[k]); strcpy(arr_str[k],temp); } } 参考答案2:用指针数组指向字符型二维数组 #includestdio.h #includestring.h void initial_string(char *name[5],int n); void sort_string(char * arr_str[],int n); void out_string(char *arr_str[],int n); void main() { char *name[5],data[5][10]; int i; for(i=0;i5;i++) //name为指针数组,其元素为5个char*指针,分别指向数组data的每一行 name[i]=data[i][0]; initial_string(name,5); sort_string(name,5); printf(排序后:\n); out_string(name,5); } void initial_string(char *name[5],int n) { printf(请输入5个名字序列:\n); for(int i=0;in;i++) scanf(%s,name[i]); } void out_string(char * arr_str[],int n) //输出 { int j; for(j=0;jn;j++) printf(%s\n,arr_str[j]); } void sort_string(char* arr_str[],int n)//主元排序 { char *temp; int i,j,k; for(i=0;in-1;i++) { k=i; for(j=i+1;jn;j++) if(strcmp(arr_str[k],arr_str[j])0) k=j; temp=arr_str[i]; arr_str[i]=arr_str[k]; arr_str[k]=temp; } } 参考答案3:用指针数组动态分配内存 #includestdio.h #includestring.h #includestdlib.h void initial_string(char *name[5],int n); void sort_string(char * arr_str[],int n); void out_string(char *arr_str[],int n); void destory(char *name[5]); void main() { char *name[5];
您可能关注的文档
- PN-FDG1纸张水份仪.doc
- 科学绘本:小蓝和小黄.ppt
- 12-重要环境因素清单2009.3.25.doc
- 主要检测设备定期检查维护保养制度.doc
- 演示文稿fashion.ppt
- 写作 1 -环保.ppt
- 第三章细胞的结构学生必背.doc
- 全日制教育硕士培养方案 学科地理 .doc
- 亚特兰大机场.ppt
- 2012年下期九年级化学期中考试题.doc
- 人教版八年级上册数学精品教学课件 第十三章 三角形 章末整合练.ppt
- 人教版八年级上册数学精品教学课件 第十五章 轴对称 15.3 等腰三角形-15.3.1 等腰三角形-第2课时 等腰三角形的判定 (4).ppt
- 人教版八年级上册数学精品教学课件 极速提分法 第17招 整体思想在解题中的七种技巧.ppt
- 人教版八年级上册数学精品教学课件 第十五章 分式 专项突破9 分式方程的解在求字母的值或取值范围中的常用技巧.ppt
- 人教版八年级上册数学精品教学课件 第十八章 分式 18.3 分式的加法与减法-第1课时 分式的加减.ppt
- 人教版八年级上册数学精品教学课件 第十四章 全等三角形 14.1 全等三角形及其性质 (4).ppt
- 七年级作文成长的经历(11篇).docx
- 法律责任豁免声明及工作证明函(6篇).docx
- 叙事作文那是一次难忘的尝试750字通用14篇.docx
- 沙滩里的秘密500字(14篇).docx
文档评论(0)