输入一个数组,讲数组中的最大值和最小值互换后输出数组
时间: 2024-05-09 13:15:23 浏览: 57
好的,以下是一个 Python 语言的示例代码:
```python
def swap_max_min(arr):
max_idx = arr.index(max(arr))
min_idx = arr.index(min(arr))
arr[max_idx], arr[min_idx] = arr[min_idx], arr[max_idx]
return arr
arr = [3, 8, 1, 9, 5]
print(swap_max_min(arr)) # 输出 [3, 1, 8, 9, 5]
```
代码中,`swap_max_min` 函数接收一个数组 `arr`,使用 `index` 函数找到数组中最大值和最小值的下标,并交换它们的位置。最后返回交换后的数组。
相关问题
c语言输入一个数组,讲数组中的最大值和最小值互换后输出数组
可以通过以下方法实现:
```c
#include <stdio.h>
int main() {
int arr[10];
int max_index = 0, min_index = 0;
// 输入数组元素
printf("请输入10个整数:\n");
for (int i = 0; i < 10; i++) {
scanf("%d", &arr[i]);
}
// 找到最大值和最小值的下标
for (int i = 1; i < 10; i++) {
if (arr[i] > arr[max_index]) {
max_index = i;
}
if (arr[i] < arr[min_index]) {
min_index = i;
}
}
// 交换最大值和最小值
int temp = arr[max_index];
arr[max_index] = arr[min_index];
arr[min_index] = temp;
// 输出数组元素
printf("交换后的数组为:\n");
for (int i = 0; i < 10; i++) {
printf("%d ", arr[i]);
}
return 0;
}
```
以上代码中,我们定义了一个长度为 10 的数组 `arr`,并通过循环输入了 10 个整数。然后我们遍历数组,找到最大值和最小值的下标,并通过一个临时变量 `temp` 交换了它们的值。最后再次循环输出数组元素即可。
输入一个正整数n,定义一个长度为n的一维数组,并输入这组一维数组,求出这个数组的最大值和最小值,并互换最大值和最小值位置后输出整个数组。c++
在C++中,你可以通过以下几个步骤来实现这个功能:
1. 首先,定义一个函数 `swapMaxMin(int arr[], int n)` 来找到并交换数组中的最大值和最小值。这里可以使用两个变量分别记录当前的最大值 `max` 和最小值 `min`,然后遍历整个数组,更新这两个变量。
```cpp
void swapMaxMin(int arr[], int n) {
int max = arr[0], min = arr[0];
for (int i = 1; i < n; ++i) {
if (arr[i] > max) {
max = arr[i];
} else if (arr[i] < min) {
min = arr[i];
}
}
// 使用 temp 变量来交换
int temp;
if (max == min) { // 如果数组全相等,则无需交换
return;
}
for (int i = 0; i < n; ++i) {
if (arr[i] == max) {
temp = arr[i]; // 找到最大值的位置
arr[i] = min;
min = temp;
break; // 最大值只会出现一次,所以一旦找到就退出循环
}
}
}
```
2. 接着,在主函数中接收用户输入的正整数 `n` 和数组元素,然后调用上述函数来交换最大值和最小值,并打印交换后的数组。
```cpp
#include <iostream>
using namespace std;
int main() {
int n;
cout << "请输入数组的长度:";
cin >> n;
int arr[n];
cout << "请输入" << n << "个整数:";
for (int i = 0; i < n; ++i) {
cin >> arr[i];
}
swapMaxMin(arr, n);
cout << "交换最大值和最小值后的数组是:";
for (int i = 0; i < n; ++i) {
cout << arr[i] << " ";
}
return 0;
}
```
阅读全文