7-10 交换最小值和最大值 分数 15 作者 C课程组 单位 浙江大学
时间: 2024-12-15 17:21:16 浏览: 105
这是一个经典的编程练习题目,通常出现在教学中用来帮助学生理解和实践数组操作。题目描述如下:
假设有一个包含两个整数的数组 [a, b],即 [7, 10],你需要通过交换这两个元素的位置来改变它们的顺序,使得数组的第一个元素成为当前的最大值,第二个元素成为最小值。在Python中,可以使用一行简洁的代码来完成这个任务:
```python
a, b = max(a, b), min(a, b)
```
这行代码首先计算出 `a` 和 `b` 中的最大值和最小值,然后将它们赋值给 `a` 和 `b`,从而实现了交换。对于给定的 [7, 10],执行上述代码后数组会变成 [10, 7]。
如果你需要编写一个函数来处理这种情况,下面是一个简单的示例:
```python
def swap_min_max(arr):
arr[0], arr[1] = arr[1], arr[0] # 直接交换
return arr
# 示例
input_array = [7, 10]
output_array = swap_min_max(input_array)
print("交换后的数组:", output_array) # 输出: [10, 7]
```
相关问题
用c语言 交换最小值和最大值 分数 10 作者 C课程组 单位 浙江大学 本题要求编写程序,先将输入的一系列整数中的最小值与第一个数交换,然后将最大值与最后一个数交换,最后输出交换后的序列。 注意:题目保证最大和最小值都是唯一的。 输入格式: 输入在第一行中给出一个正整数N(≤10),第二行给出N个整数,数字间以空格分隔。 输出格式: 在一行中顺序输出交换后的序列,每个整数后跟一个空格。 输入样例: 5 8 2 5 1 4 输出样例: 1 2 5 4 8
好的,请参考以下C语言代码实现:
```
#include <stdio.h>
#include <stdlib.h>
int main() {
int n, a[10];
scanf("%d", &n);
for (int i = 0; i < n; i++) {
scanf("%d", &a[i]);
}
// 找到最小值和最小值的下标
int min = a[0], min_index = 0;
for (int i = 1; i < n; i++) {
if (a[i] < min) {
min = a[i];
min_index = i;
}
}
// 将最小值和第一个数交换
int temp = a[0];
a[0] = min;
a[min_index] = temp;
// 找到最大值和最大值的下标
int max = a[0], max_index = 0;
for (int i = 1; i < n; i++) {
if (a[i] > max) {
max = a[i];
max_index = i;
}
}
阅读全文
相关推荐













