字符串排序(指针)

来源:互联网 发布:java文本相似度 tfidf 编辑:程序博客网 时间:2024/05/27 18:17

从主函数输入十个不等长的字符串,编写函数,对这些串进行排序,在主调函数中输出排好序的串。

#include<stdio.h>
#include<string.h>
void fun(char *p1[10])
{
 int i,j;
 char *pt;                   //定义临时指针变量,用于交换地址
 for(i=0;i<9;i++)
       for(j=0;j<9-i;j++)
       if(strcmp(p1[j],p1[j+1])>0)
       {
        pt=p1[j];p1[j]=p1[j+1];p1[j+1]=pt;     //若前字符串大于后字符串,则交换地址(未交换字符串)
    }
 }
 int main()
 {
  int i,j;
  char s[10][30];
  char *p[10];
  for(i=0;i<10;i++)
     p[i]=s[i];    
  printf("请输入10个字符串\n");
  for(i=0;i<10;i++)
     gets(p[i]);
  fun(p);
  printf("排列好的顺序为\n");
  for(i=0;i<10;i++)
  printf("%s\n",*(p+i));           //*(p+i)代表这一行的字符,也就是字符串
  return 0;
 }








原创粉丝点击