我想用冒泡排序算一遍,但结果是 # red blue green yellow purple
虽然排出来了,但特殊符号咋来的,如何改进
#include<stdio.h>
#include<string.h>
int main()
{
char a[22][11];
int t=0;
for(int i=0;i<21&&a[i][0]!='#';i++)
{
scanf("%s",&a[i]);
t++;
}
for(int i=0;i<t-1;i++)
for(int j=0;j<t-i-2;j++)
if(strlen(a[j])>strlen(a[j+1]))
{
char b[20];
strcpy(b,a[j]);
strcpy(a[j],a[j+1]);
strcpy(a[j+1],b);
}
for(int i=0;i<t-1;i++)
printf("%s ",a[i]);
return 0;
}
因为你的字符串“#”,是作为输入结束的标志字符串的。你是先scanf,再去判断“#”的,多算一了一个字符串,t再-1就好了
修改见注释,供参考:
#include <stdio.h>
#include <string.h>
int main()
{
char a[22][11];
int t = 0;
for (int i = 0; i < 22; i++) //for (int i = 0; i < 21 && a[i][0] != '#'; i++)
{
scanf("%s", a[i]); //scanf("%s", &a[i]);
if (strcmp(a[i], "#") == 0) break; //修改
t++;
}
for (int i = 0; i < t - 1; i++)
for (int j = 0; j < t - i - 1; j++) //for (int j = 0; j < t - i - 2; j++)
if (strcmp(a[j], a[j + 1]) > 0) //if (strlen(a[j]) > strlen(a[j + 1]));
{
char b[20];
strcpy(b, a[j]);
strcpy(a[j], a[j + 1]);
strcpy(a[j + 1], b);
}
for (int i = 0; i < t; i++) //for (int i = 0; i < t - 1; i++)
printf("%s ", a[i]);
return 0;
}
我这边无法正常停止输入,可能我用C++编译器编译的,就算输入#也没用(你的第8行的判定有点问题。)
我改成这样子就OK了
#include<stdio.h>
#include<string.h>
int main()
{
char a[22][11];
int t=0;
for(int i=0;i<21;i++)
{
scanf("%s",&a[i]);
if(a[i][0]=='#')break;
t++;
}
for(int i=0;i<t-1;i++)
for(int j=0;j<t-i-2;j++)
if(strlen(a[j])>strlen(a[j+1]))
{
char b[20];
strcpy(b,a[j]);
strcpy(a[j],a[j+1]);
strcpy(a[j+1],b);
}
for(int i=0;i<t-1;i++)
printf("%s ",a[i]);
return 0;
}
希望能够帮到您,记得点个采纳哦