ch07数组和指针数组.ppt

  1. 1、本文档共14页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
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];

文档评论(0)

qwd513620855 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档