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

用起泡法和选择法怎么将字符串按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 跑hls xfopencv的例程standalone_hls_axi_example出的错误,csim没问题,c synthesis出的错误
  • ¥15 sqlserver update语句逐行生效
  • ¥15 mssql2000游标循环次数对不上
  • ¥20 Windows10系统命令行调用
  • ¥15 php环境如何实现国密SM2相关功能
  • ¥15 关于#单片机#的问题:K210 例程里面提示我iomem.h: No such file or directory
  • ¥15 LSPI算法的大问题
  • ¥15 java导出word 动态填充数据
  • ¥20 扑克的算牌公式及软件制作
  • ¥20 如何通过云图中RPG去计算云图上不同位置的值?