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;
}