编程,在主函数中输入10个最长不超过20个字符的字符串,用另一个函数完成对这10个字符串降序排序,然后在主函数中再输出排序后的字符串。

程序有问题,不会改,求解答,我还没学 ** 这个东西


#include<stdio.h>
#include<string.h>
void fpx(char (*p)[20],int k)
{
    int j,i;
    char max[20]={'\0'};
    for(i=0;i<k;i++)
        for(j=i;j<10;j++)
            if(strcmp(p[i],max[20])) 
            {
                strcpy(max[20],p[j]);
                strcpy(p[j],p[i]);
                strcpy(p[i],max[20]);
                //对每一列进行查找,找出最大的一串复制到第i行上
            }
}
}
int main()
{
    char a[10][20],(*pa)[20]=a;
    int i,k=0,c;
    printf("请获得十串字符串:\n");
    for(i=0;i<10;i++)
        scanf("%s",*(pa+i));
    k=strlen(a[0]);
    for(i=1;i<10;i++)
        if(strlen(*(pa+i))>k) k=strlen(*(pa+i)); //找出字符长度最长的一串
    fpx(a,k);
    for(i=0;i<10;i++)
        printf("%s",*(pa+i));
    return 0;
}

如果时让10个字符串按ASCII码排序的话,main函数里那个判断字符串长度的代码似乎不需要,稍微修改了一下排序字符串函数fpx的逻辑,修改如下:


 
#include<stdio.h>
#include<string.h>
void fpx(char (*p)[20],int k)
{
    int j,i;
    char max[20];
    strcpy(max,p[0]);
    for(i=0;i<10;i++)
        for(j=i;j<10;j++)
         //如果第j个字符串比第i个字符串的ASCII码比较大,则把j位置的字符串移到前面i位置,达到降序排列的目的 
            if(strcmp(p[j],p[i])>0) 
            {
                strcpy(max,p[j]);
                strcpy(p[j],p[i]);
                strcpy(p[i],max);
                //对每一列进行查找,找出最大的一串复制到第i行上
            }
}

int main()
{
    char a[10][20],(*pa)[20]=a;
    int i,k=0,c;
    printf("请获得十串字符串:\n");
    for(i=0;i<10;i++)
        scanf("%s",*(pa+i));
    k=strlen(a[0]);
    for(i=1;i<10;i++)
        if(strlen(*(pa+i))>k) k=strlen(*(pa+i)); //找出字符长度最长的一串
    fpx(a,10); 
    printf("字符串排序后:\n");
    for(i=0;i<10;i++)
        printf("%s\n",*(pa+i));
    return 0;
}

fpx中循环的判断条件,k换成10,其实我没看出来k有什么用。你修改跑一下试试