用C语言输入10个元素的数组,然后把最小的那个元素跟第一个元素交换位置,并把最大的那个元素跟最后一个元素交换位置。 我的答案:
时间: 2024-09-08 19:03:49 浏览: 38
首先,需要包含必要的头文件,并声明一个数组来存储输入的10个元素。接着,编写代码以遍历数组,寻找最小和最大元素的位置,并记录它们的值。最后,通过交换操作,将最小元素与数组的第一个元素交换位置,将最大元素与数组的最后一个元素交换位置。以下是具体实现步骤:
1. 包含标准输入输出头文件 `<stdio.h>`。
2. 声明一个整型数组 `arr` 用于存储10个元素。
3. 使用循环结构输入10个整数填充数组。
4. 使用两个循环分别找到最小和最大元素的位置,同时记录最小和最大元素的值。
5. 交换最小元素与数组第一个元素的位置。
6. 交换最大元素与数组最后一个元素的位置。
7. 输出交换后的数组,验证结果。
下面是C语言的具体代码实现:
```c
#include <stdio.h>
int main() {
int arr[10];
int i;
int min_val = arr[0];
int min_index = 0;
int max_val = arr[0];
int max_index = 0;
// 输入10个元素
printf("请输入10个整数:\n");
for (i = 0; i < 10; i++) {
scanf("%d", &arr[i]);
}
// 寻找最小元素的位置
for (i = 1; i < 10; i++) {
if (arr[i] < min_val) {
min_val = arr[i];
min_index = i;
}
}
// 寻找最大元素的位置
for (i = 0; i < 10; i++) {
if (arr[i] > max_val) {
max_val = arr[i];
max_index = i;
}
}
// 交换最小元素与第一个元素的位置
if (min_index != 0) {
int temp = arr[0];
arr[0] = arr[min_index];
arr[min_index] = temp;
}
// 交换最大元素与最后一个元素的位置
if (max_index != 9) {
int temp = arr[9];
arr[9] = arr[max_index];
arr[max_index] = temp;
}
// 输出交换后的数组
printf("交换后的数组:\n");
for (i = 0; i < 10; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
```
阅读全文