#include<stdio.h>
#include<string.h>
void paixu(char *pa);
char name[10][20];
void main()
{
printf("输入");
for(int i=0;i<10;i++)
{
gets(name[i]);
}
paixu(name[0]);
}
void paixu(char *pa)
{
char x[20];
for(int j=0;j<9;j++)
{
for(int i=j+1;i<10;i++)
{
if(strcmp(pa+i,pa+j)<0)
{
strcpy(x,pa+i);
strcpy(pa+i,pa+j);
strcpy(pa+j,x);
}
}
}
for(int i=0;i<10;i++)
{
puts(pa+i);
}
}
这是一个输入十个国家的英文名,按升序排序后输出的函数。哪里错了!!!!!!
江湖救急,江湖救急,在线等!!!!!
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- 小白小白你好菜 2021-06-19 22:26关注
这个也是在你的基础上改的,指针 #include<stdio.h> #include<string.h> void paixu(char (*pa)[20]); char name[10][20]; int main() { printf("输入:\n"); for(int i=0;i<10;i++) { gets(name[i]); } paixu(name); return 0; } void paixu(char (*pa)[20]) //name为二维数组的地址,所以用行指针去对应赋值 { char pb[20]; for(int j=0;j<9;j++) { for(int i=j+1;i<10;i++) { if(strcmp(*(pa+j),*(pa+i))>0) //注意是name[0]和name[1]的比较,所以加* { strcpy(pb, pa[j]); strcpy(pa[j], pa[i]); strcpy(pa[i], pb); } } } for(int i=0;i<10;i++) { puts(pa[i]); } }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥20 机器学习能否像多层线性模型一样处理嵌套数据
- ¥20 西门子S7-Graph,S7-300,梯形图
- ¥50 用易语言http 访问不了网页
- ¥50 safari浏览器fetch提交数据后数据丢失问题
- ¥15 matlab不知道怎么改,求解答!!
- ¥15 永磁直线电机的电流环pi调不出来
- ¥15 用stata实现聚类的代码
- ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
- ¥20 docker里部署springboot项目,访问不到扬声器
- ¥15 netty整合springboot之后自动重连失效