注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

Mr.Right

不顾一切的去想,于是我们有了梦想。脚踏实地的去做,于是梦想成了现实。

 
 
 

日志

 
 
关于我

人生一年又一年,只要每年都有所积累,有所成长,都有那么一次自己认为满意的花开时刻就好。即使一时不顺,也要敞开胸怀。生命的荣枯并不是简单的重复,一时的得失不是成败的尺度。花开不是荣耀,而是一个美丽的结束,花谢也不是耻辱,而是一个低调的开始。

网易考拉推荐

阿英讲指向指针的指针对2维字符数组排序  

2013-09-12 23:15:08|  分类: 编程 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
即以此功德,庄严佛净土。上报四重恩,下济三途苦。惟愿见闻者,悉发菩提心。在世富贵全,往生极乐国。

/* input STRINGS_NO strings
China
America
India
Philippine
Canada
*/
#include <stdio.h>
#include <string.h>
# define LINEMAX 20 // maximum length of a string
# define STRINGS_NO 5

int main(int argc, char *argv[])
{
void sort(char **p);  // function declaration
int i;
char **p, *pstr[STRINGS_NO], str[STRINGS_NO][LINEMAX];
for (i = 0; i < STRINGS_NO; i++)
pstr[i] = str[i]; // str[i] is a static pointer
printf("input %d strings: \n", STRINGS_NO);
for (i = 0; i < STRINGS_NO; i++)
scanf("%s", pstr[i]);  // pstr is a pointer array
p = pstr; // p = str will incurr an error in sort() function, since str is a static pointer
sort(p);
printf("\n strings sorted: \n");
for ( i = 0; i < STRINGS_NO; i++)
printf("%s\n", pstr[i]);
return 0;
}

void sort(char **p)   // selection sort
{
int i, j, idxMin;
char *temp;
for (i = 0; i < STRINGS_NO - 1; i++)
{
idxMin = i;
for (j = i + 1; j < STRINGS_NO; j++)
if (strcmp(*(p + j), *(p + idxMin)) < 0)
idxMin = j;
if (idxMin != i)   // exchange 2 pointer: *(p + i) and *(p + idxMin)
{
temp = *(p + i);
*(p + i) = *(p + idxMin);
*(p + idxMin) = temp;
}
}
}
阿英讲指向指针的指针对2维字符数组排序 - 阿英 - Mr.Right
 
  评论这张
 
阅读(336)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2016