字符串的选择排序-指针排序

#include <stdio.h>
#include <string.h>
#define SIZE 80     //限制字符串的长度
#define LIM 20      //可读入的最多行数
char *s_gets(char *st,int size);
void ststr(char *strings[],int num);
int main()
{
    char *ptstr[LIM];           //内涵指针变量的数组
    int ct=0;                   //输入的行数计数
    char input[LIM][SIZE];      //存储输入的数组
    while(s_gets(input[ct],SIZE)!=NULL&&ct<LIM&&input[ct][0]!='\0')
    {
        ptstr[ct]=input[ct];    //指针指向字符串
        ct++;
    }
    ststr(ptstr,ct);            //字符串的排序
    for(int i=0;i<ct;i++)       //输出指针排序之后的字符串
          puts(ptstr[i]);
    return 0;
}
char *s_gets(char *st,int size)
{
    char *ret_val;
    int i=0;
    ret_val=fgets(st,size,stdin);
    if(ret_val)
    {
        while(st[i]!='\n'&&st[i]!='\0')
            i++;
        if(st[i]=='\n')
            st[i]='\0';
        else
            while(getchar()!='\n')
            continue;
    }
    return ret_val;
}
void ststr(char *strings[],int num)
{


    char *teme;
    for(int i=0;i<num-1;i++)
    {
        for(int j=i+1;j<num;j++)
        {
            if(strcmp(strings[i],strings[j])>0)
            {
                teme=strings[j];
                strings[j]=strings[i];
                strings[i]=teme;
            }
        }
    }
}
 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值