【问题描述】 编写一个程序,从键盘接收一个字符串(长度不超过20),采用插入排序,按照字符顺序从小到大进行排序,最后输出排序后的字符串。

求大佬解答
【问题描述】
编写一个程序,从键盘接收一个字符串(长度不超过20),采用插入排序,按照字符顺序从小到大进行排序,最后输出排序后的字符串。
【输入形式】
输入一行字符串,长度不超过20。
【输出形式】
输出排序后的字符串。
【样例输入】
H2e3L*Lo,Wor#Ld.
【样例输出】
#*,.23HLLLWdeoor

问题解决的话,请点下采纳,以及之前的问题 https://ask.csdn.net/questions/1001509 也点下采纳,谢谢

之前看错了下面是插入排序

#include <stdio.h>
#include <string.h>
int main()
{
    char a[21];
    scanf("%s",a);
    int t,j=0,i=0;
    int n = strlen(a);
    for(j=1;j < n; j++){
        for(i=0;i<j;i++) {
            if (a[i] > a[j]) break;
        }
        int t=a[j];
        int t1;
        for(;i<=j;i++){
            t1=a[i];
            a[i]=t;
            t=t1;
        }
    }
    printf("%s",a);
    return 0;
}

https://ideone.com/QL7g22 在线调试通过

下面是选择排序

#include <stdio.h>
#include <string.h>
int main()
{
    char a[21];
    scanf("%s",a);
    int t,j=0,i=0;
    int n = strlen(a);
    for(j=0;j < n - 1; j++){
        int min = j;
        for(i=j+1;i < n; i++) {
            if (a[i] < a[min]) min=i;
        }
        if (min != j) {
            t=a[min];
            a[min]=a[j];
            a[j]=t;
        }
    }
    printf("%s",a);
    return 0;
}

#include<stdio.h>
#include<string.h>
#include<math.h>

void str_px(char str1[ ])
{

int len;
len=strlen(str1);
int i,j,k;
char str[100];
int flag;

for(i=0;i<len;i++)
{
    for(j=i+1;j<len;j++)
    {
        if(str1[i]>str1[j])
        {
            char c;
            c=str1[i];
            str1[i]=str1[j];
            str1[j]=c;
        }
    }
}
for(i=0;i<len;i++)
{
    flag=0;
    for(j=i+1;j<len;j++)
    {
        if(str1[j]==str1[i])
            str1[j]=' ';
    }
}
for(i=0;i<len;i++)
{
    if(str1[i]!=' ')
        printf("%c",str1[i]);
}

}

int main()
{
char str[100];
scanf("%s",&str);

str_px(str);

return 0;

}