-cfyjbjonn 2019-04-24 22:10 采纳率: 57.1%
浏览 1544
已采纳

急求!!!请问我错在哪里?以及怎么改?谢谢!!!c语言 给国家的名称按字典顺序排序

请用指针数组编程实现按奥运会参赛国国名,在字典中的顺序对其入场次序进行排序。
假设参赛国不超过150个。
下面程序中存在比较隐蔽的错误,请通过分析和调试程序,发现并改正程序中的错误。
注意:请将修改正确后的完整源程序拷贝粘贴到答题区内。
对于没有错误的语句,请不要修改,修改原本正确的语句也要扣分。
当且仅当错误全部改正,且程序运行结果调试正确,才给加5分。
经教师手工核对后,如果未用指针数组做函数参数编程,那么即使做对也不给分。
改错时不能改变程序原有的意图,不能改变函数原型。
#include
#define MAX_LEN 10
#define N 150
void SortString(char *ptr[], int n);
main()
{
int i, n;
char *pStr[N];
printf("How many countries?\n");
scanf("%d",&n);
printf("Input their names:\n");
for (i=0; i<n; i++)
{
gets(pStr[i]);
}
SortString(pStr[i], n);
printf("Sorted results:\n");
for (i=0; i<n; i++)
{
puts(pStr[i]);
}
}

void SortString(char *ptr[], int n)
{
int i, j;
char temp;
for (i=0; i<n-1; i++)
{
for (j = i+1; j<n; j++)
{
if (ptr[j] < ptr[i]);
{
temp = ptr[i];
ptr[j] = ptr[i];
ptr[j] = temp;
}
}
}
}

#include  <stdio.h>
#include <string.h>
#define   MAX_LEN  10
#define   N         150
void SortString(char *ptr[], int n);
int main()
{
    int    i, n;
    char   *pStr[N];
    printf("How many countries?\n");
    scanf("%d", &n);
    getchar();
    printf("Input their names:\n");
    for (i = 0; i < n; i++)
    {
        gets(pStr[i]);
    }
    SortString(pStr, n);
    printf("Sorted results:\n");
    for (i = 0; i < n; i++)
    {
        puts(pStr[i]);
    }
    return 0;
}

void SortString(char *ptr[], int n)
{
    int    i, j;
    char  *temp;
    for (i = 0; i < n - 1; i++)
    {
        for (j = i + 1; j < n; j++)
        {
            if (strcmp(ptr[j] , ptr[i]) < 0 )
            {

                temp = ptr[j];
                ptr[j] = ptr[i];
                ptr[i] = temp;
            }
        }
    }
}

  • 写回答

2条回答 默认 最新

  • 白色一大坨 2019-04-25 13:32
    关注

    错在哪里都给你注释了,看看吧:

    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    #define MAX_LEN 10
    #define N 150
    void SortString(char *ptr[], int n);
    int main()
    {
        int i, n;
        char *pStr[N];
        printf("How many countries?\n");
        scanf("%d", &n);
        if (n> N)//输入n值判断
        {
            printf("n  greater than 150\n");
            return 0;
        }
    
        getchar();
        for (i = 0; i < n;i++)//动态分配
        {
            pStr[i] = (char *)malloc(32);
        }
        printf("Input their names:\n");
        for (i = 0; i < n; i++)
        {
            gets(pStr[i]);
        }
        SortString(pStr, n);
        printf("Sorted results:\n");
        for (i = 0; i < n; i++)
        {
            puts(pStr[i]);
        }
        for (i = 0; i < n; i++)//释放资源
        {
            free(pStr[i]);
        }
        return 0;
    }
    
    void SortString(char *ptr[], int n)
    {
        int i, j;
        char temp[32];
        for (i = 0; i < n - 1; i++)
        {
            for (j = i + 1; j < n; j++)
            {
                if (strcmp(ptr[j], ptr[i]) < 0)
                {
                    strcpy(temp, ptr[i]);
                    strcpy(ptr[i], ptr[j]);//序号反了
                    strcpy(ptr[j], temp);
                }
            }
        }
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制