解题思路: 定义一个含有10个元素的数组,找出其中最大值与最小值的编号,分别记为min,max;按要求进行交换,同时考虑特殊情况的处理。
注意事项:
如何解决部分测试结果不正确的问题?
特殊情况1:
当最大值在数组的首位时,比如 10,1 ,2,3,4,5,6,7,8,9;min=1,max=0
如果先交换最小值和首位数字,即数组变为1,10,2,3,4,5,6,7,8,9;
此时,最大值并非在原来的位置,而是从max=0,变成了max=min=1,如果依然按照max=0,进行交换,
将会得到错误的结果,也就是9,10,2 ,3,4,5,6,7,8,1;
然而,正确的结果其实是将移动后的最大值与最后一个数交换,这样才能得出正确的结果,
1,9,2,3,4,5,6,7,8,10
特殊情况2:
最小值恰好在开头,最大值恰好在结尾,此时将不会执行交换的步骤,直接打印结果。
参考代码:
/*输入10个整数,将其中最小的数与第一个数对换,把最大的数与最后一个 数对换。写三个函数; ①输入10个数;②进行处理;③输出10个数。*/ #include<iostream> using namespace std; int main() { int str[10]; int n; int max = 9; int min = 0; //循环输入10个数 for(int i = 0; i < 10; i++) { cin >> n; str[i] = n; } //寻找最小与最大编号 for (int j = 0; j < 10; j++) { if (str[min] > str[j]) { min = j; } if (str[max] < str[j]) { max = j; } } //进行交换 if (min != 0) { int temp1 = str[min]; str[min] = str[0]; str[0] = temp1; } //考虑最大值在开头的特殊情况 if (max != 9 && max != 0) { int temp2 = str[max]; str[max] = str[9]; str[9] = temp2; } //最大值如果在首位,由于前面交换最小值时,最大值编号已经发生变化,故需做出改变 else if(max == 0) { max = min;//改变后最大值恰好为原最小值编号min; int temp = str[max]; str[max] = str[9]; str[9] = temp; } for (int i = 0; i < 10; i++) { cout << str[i] << " "; } return 0; }
0.0分
1 人评分
【蟠桃记】 (C语言代码)浏览:697 |
WU-输入输出格式练习 (C++代码)浏览:1133 |
A+B for Input-Output Practice (VI) (C语言代码)浏览:575 |
2^k进制数 (C语言描述,蓝桥杯)浏览:1457 |
淘淘的名单 (C语言代码)浏览:1309 |
1162答案错误,为什么浏览:700 |
2003年秋浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:748 |
剔除相关数 (C语言代码)浏览:1156 |
简单的a+b (C语言代码)浏览:538 |
逆反的01串 (C语言代码)浏览:1527 |