#include <stdio.h>
void input (int a[10]);
void trans (int a[10]);
void output(int a[10]);
int main()
{
int a[10];
input(a);
trans(a);
output(a);
return 0;
}
void input(int a[10]){
int i;
for(i=0;i<10;i++){
scanf("%d",&a[i]);
}
}
void trans(int a[10]){
int i,max=a[0],min=a[0];
int mark_max=0,mark_min=0;
for(i=0;i<10;i++){
if(a[i]>max){
max=a[i];
mark_max=i;
}
else if(a[i]<min){
min=a[i];
mark_min=i;
}
}
int t;
t=a[0];
a[0]=a[mark_min];
a[mark_min]=t;
if(!(mark_max==0 && mark_min==9)){//防止首末互换两次情况出现
t=a[9];
a[9]=a[mark_max];
a[mark_max]=t;
}
}
void output(int a[10]){
int i;
for(i=0;i<10;i++){
printf("%d ",a[i]);
}
printf("\n");
}
谁能帮我看看错在哪里吗?显示答案错误,谢谢
0.0分
0 人评分
#include <stdio.h> void input (int a[10]); void trans (int a[10]); void output(int a[10]); int main() { int a[10]; input(a); trans(a); output(a); return 0; } void input(int a[10]) { int i; for(i=0;i<10;i++) { scanf("%d",&a[i]); } } void trans(int a[10]) { int i,max=a[9],min=a[0]; int mark_max=0,mark_min=0; for(i=0;i<10;i++) { if(a[i]>max){max=a[i];mark_max=i;} else if(a[i]<min){min=a[i];mark_min=i;} } int t; t=a[9]; a[9]=max; a[mark_max]=t; t=a[0]; a[0]=min; a[mark_min]=t; } void output(int a[10]){ int i; for(i=0;i<10;i++){ printf("%d ",a[i]); } printf("\n"); }
#include <stdio.h> void input (int a[10]); void trans (int a[10]); void output(int a[10]); int main() { int a[10]; input(a); trans(a); output(a); return 0; } void input(int a[10]){ int i; for(i=0;i<10;i++){ scanf("%d",&a[i]); } } void trans(int a[10]){ int i,max=a[9],min=a[0]; int mark_max=0,mark_min=0; for(i=0;i<10;i++){ if(a[i]>max){ max=a[i]; mark_max=i; } else if(a[i]<min){ min=a[i]; mark_min=i; } } int t; t=a[9]; a[9]=max; a[mark_max]=t; t=a[0]; a[0]=min; a[mark_min]=t; } void output(int a[10]){ int i; for(i=0;i<10;i++){ printf("%d ",a[
第一 把max=a[0]改为max=a[9]; 第二 把if(!(mark_max==0 && mark_min==9))语句和它所带{}删掉 第三 把t=a[9]; a[9]=a[mark_max]; a[mark_max]=t; 放到t=a[0]; a[0]=a[mark_min]; a[mark_min]=t;的前面 也就是先换大再换小的。
dudulooooo 2017-10-09 19:38:42 |
你贴一个错误答案算什么
旧时光丶 2017-10-14 01:16:14 |
#include <stdio.h> void input (int a[10]); void trans (int a[10]); void output(int a[10]); int main() { int a[10]; input(a); trans(a); output(a); return 0; } void input(int a[10]){ int i; for(i=0;i<10;i++){ scanf("%d",&a[i]); } } void trans(int a[10]){ int i,max=a[9],min=a[0]; int mark_max=0,mark_min=0; for(i=0;i<10;i++){ if(a[i]>max){ max=a[i]; mark_max=i; } else if(a[i]<min){ min=a[i]; mark_min=i; } } int t; t=a[9]; a[9]=max; a[mark_max]=t; t=a[0]; a[0]=min; a[mark_min]=t; } void output(int a[10]){ int i; for(i=0;i<10;i++){ printf("%d ",a[i]); } printf("\n"); }
校门外的树 (C语言代码)浏览:1155 |
K-进制数 (C++代码)浏览:931 |
C语言程序设计教程(第三版)课后习题6.1 (C语言代码)浏览:643 |
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:1144 |
C语言程序设计教程(第三版)课后习题5.7 (C++代码)浏览:874 |
哥德巴赫曾猜测 (C语言代码)浏览:1068 |
不容易系列 (C语言代码)浏览:698 |
WU-蓝桥杯算法提高VIP-勾股数 (C++代码)浏览:1665 |
C语言训练-求s=a+aa+aaa+aaaa+aa...a的值 (C语言代码)浏览:750 |
2003年秋浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:562 |