关于C语言字符串的问题xdoj

xdoj单词排序求改错

/*
定义一个二维字符数组str[10][20],行号表示单词序号,
列号表示单词最大长度,输入一个正整数N(N≤10),表示单词数,
使用函数wd_sort()完成单词的排序,按字母顺序从小到大排列单词,
使用指针完成地址传递,主函数完成数组输入和输出。

输入说明
输入一个二维字符数组str和一个正整数N,行号表示单词序号,列号表示单词最大长度。

输出说明
格式输出:单词之间空一行。

输入样例
3
word fish egg
输出样例
egg
fish
word

提示
使用指针作形参,实现地址传递。
数组定义后初始化。
使用strcmp()、strcpy()和strlen()函数,头文件string.h。
*/
#include 
#include <string.h>
void wd_sort(char *string[], int n);
int main()       
{
    int n, i=0;
    scanf("%d", &n);
    char str[10][20];
    for (i=0; i"%s", &str[i]);
    }
    wd_sort(str, n);
    for (i=0; i//puts(str[i]);
        printf("%s\n", str[i]);
    }
    return 0;
}

void wd_sort(char *string[], int n)
{
    char *temp;
    int i, j;
    for (i=0; i1; i++)
    {
        for (j=i+1; jif (strcmp(string[i], string[j])>0)
            {
                temp=string[i];
                string[i]=string[j];
                string[j]=temp;
            }
        }
    }
}

一直运行不正确


int main()
{
   int n, i = 0;
   scanf("%d", &n);
   // char str[10][20];
   char **str = (char **)(malloc(n * sizeof(char *))); //

   for (i = 0; i < n; i++)
   {
      str[i] = (char *)malloc(20); //
      scanf("%s", str[i]);         //
   }
   wd_sort(str, n);
   for (i = 0; i < n; i++)
   {
      // puts(str[i]);
      printf("%s\n", str[i]);
   }
   return 0;
}

在 main 函数中,scanf 函数读入字符串时应该使用 "%s" 而不是 "%&s"。

修改后的代码如下:

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

void wd_sort(char *string[], int n);

int main()       
{
    int n, i=0;
    scanf("%d", &n);
    char str[10][20];
    for (i=0; i<n; i++)
    {
        scanf("%s", str[i]);
    }
    wd_sort(str, n);
    for (i=0; i<n; i++)
    {
        //puts(str[i]);
        printf("%s\n", str[i]);
    }
    return 0;
}

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

参考实现如下,望采纳

#include<stdio.h>
#include<string.h>
#define ROW 10
#define COL 20
void wd_sort(char *str[], int n) {
    for (int i=0;i<n-1;i++) {
        for (int j=0;j<n-1-i;j++) {
            if(strcmp(str[j],str[j+1])>0) {
                char tmp[ROW];
                strcpy(tmp,str[j]);
                strcpy(str[j],str[j+1]);
                strcpy(str[j+1],tmp);
            }
        }
    }
}
int main() {
    char str[ROW][COL]= { 0 };
    int n;
    scanf("%d",&n);
    for (int i=0;i<n;i++)
    scanf("%s",str[i]);
    wd_sort(str,n);
    for (int i=0;i<n;i++)
        printf("%s\n",str[i]);
    return 0;
}