Deity.342 2022-05-20 17:00 采纳率: 88.9%
浏览 1216
已结题

用起泡法和选择法怎么将字符串按ascll码值从小到大排列啊


#include"stdio.h"
#include "string.h"
void main()
{
    int i,j,n;
    char t;
    char c[100];
    n=strlen(c);
    printf("请?输?入?一?个?字?符?串?:阰");
    gets(c);
    n=strlen(c);
    for(i=0;i<n-1;i++)
    {    
        for(j=0;j<n-1-i;j++)
        {
            if(c[j]>c[j+1])
            {
                t=c[j];c[j]=c[j+1];c[j+1]=t;

            }
        }
    }
    printf("排?序ò后ó的?字?符?串?为a:");
    puts(c);
}
  • 写回答

1条回答 默认 最新

  • 树下等苹果 2022-05-20 23:20
    关注

    起泡法就是你写的那个,选择排序法如下:

    
    #include"stdio.h"
    #include "string.h"
    void main()
    {
        int i, j, n;
        char t;
        char c[100];
        printf("请输入一个字符串:");
        gets(c);
        n = strlen(c);
        //for (i = 0; i < n - 1; i++)          //冒泡排序
        //{
        //    for (j = 0; j < n - 1 - i; j++)
        //    {
        //        if (c[j] > c[j + 1])
        //        {
        //            t = c[j]; c[j] = c[j + 1]; c[j + 1] = t;
    
        //        }
        //    }
        //}
        for (i = 0; i < n - 1; i++)     //选择排序
            for (j = i + 1; j < n; j++)
                if (c[i] > c[j])
                {
                    t = c[j]; c[j] = c[i]; c[i] = t;
                }
        printf("排序后的字符串为a:");
        puts(c);
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

    报告相同问题?

    问题事件

    • 系统已结题 5月29日
    • 已采纳回答 5月21日
    • 创建了问题 5月20日

    悬赏问题

    • ¥15 MYSQL 订单的商品明细重复计算问题
    • ¥15 微信实时共享位置修改
    • ¥100 TG的session协议号转成直登号号后客户端登录几分钟后自动退出设备
    • ¥30 共模反馈回路的小信号增益
    • ¥15 arduino ssd1306函数与tone函数放歌代码不兼容问题
    • ¥70 0.96版本hbase的row_key里含有双引号,无法deleteall
    • ¥40 Ida Pro增加插件出现问题
    • ¥15 诊断性META分析合并效能的检验
    • ¥15 请问abb根据色块判断奇偶数并根据批次号放入仓储
    • ¥66 开发PC客户端一定也要开发上位机吗?