输入5个整数,保存到整型数组a[5]中。将最小值与第一个数交换,最大值 与最后一个数交换,然后输出交换后的5个数。用c++
时间: 2024-03-20 21:45:27 浏览: 48
好的,下面是实现代码:
```c++
#include <iostream>
using namespace std;
int main() {
int a[5];
for(int i = 0; i < 5; i++) {
cin >> a[i];
}
int minIndex = 0, maxIndex = 0;
for(int i = 1; i < 5; i++) {
if(a[i] < a[minIndex]) {
minIndex = i;
}
if(a[i] > a[maxIndex]) {
maxIndex = i;
}
}
int temp = a[0];
a[0] = a[minIndex];
a[minIndex] = temp;
temp = a[4];
a[4] = a[maxIndex];
a[maxIndex] = temp;
for(int i = 0; i < 5; i++) {
cout << a[i] << " ";
}
cout << endl;
return 0;
}
```
这个程序首先读入五个整数,然后遍历一遍数组,找到最小值和最大值所在的位置。然后将最小值与第一个数交换,最大值与最后一个数交换。最后输出交换后的五个数。
相关问题
c++ 输入五个整数,保存到整型数组a【5】中,将最小值与第一个数交换,最大值与最后一个数交换,然后输出交换后的5个数
好的,我知道你的问题了。对于你的问题,可以按照以下步骤进行解决:
1. 首先,定义一个长度为5的整型数组a[5],用于存储输入的5个整数。
2. 然后,利用循环语句,将5个整数依次存储到数组a中。
3. 接着,定义两个变量min和max,分别表示数组a中的最小值和最大值,并将它们初始化为数组a中的第一个元素。
4. 再次利用循环语句,依次遍历数组a中的每一个元素,找到其中的最小值和最大值,分别赋值给变量min和max。
5. 然后,将数组a中的第一个元素与变量min所代表的最小值进行交换。
6. 最后,将数组a中的最后一个元素与变量max所代表的最大值进行交换。
7. 输出交换后的5个数。
下面是代码实现:
```c++
#include <iostream>
using namespace std;
int main()
{
int a[5], min, max;
cout << "请输入5个整数:" << endl;
for (int i = 0; i < 5; i++) {
cin >> a[i];
}
min = max = a[0];
for (int i = 1; i < 5; i++) {
if (a[i] < min) {
min = a[i];
}
if (a[i] > max) {
max = a[i];
}
}
int temp = a[0];
a[0] = min;
for (int i = 0; i < 5; i++) {
if (a[i] == min) {
a[i] = temp;
break;
}
}
temp = a[4];
a[4] = max;
for (int i = 0; i < 5; i++) {
if (a[i] == max) {
a[i] = temp;
break;
}
}
cout << "交换后的5个数为:";
for (int i = 0; i < 5; i++) {
cout << a[i] << " ";
}
cout << endl;
return 0;
}
```
希望我的回答能够帮到你。如果你还有其他问题,可以继续问我。
本题要求编写程序,先将输入的一系列整数中的最小值与第一个数交换,然后将最大值与最后一个数交换,最后输出交换后的序列。 注意:题目保证最大和最小值都是唯一的。用C语言一维数组编写
以下是用 C 语言一维数组编写的程序,实现题目要求的功能:
```c
#include <stdio.h>
int main() {
int n, i, min_idx, max_idx, temp;
scanf("%d", &n);
int arr[n];
for (i = 0; i < n; i++) {
scanf("%d", &arr[i]);
}
min_idx = max_idx = 0;
for (i = 1; i < n; i++) {
if (arr[i] < arr[min_idx]) {
min_idx = i;
}
if (arr[i] > arr[max_idx]) {
max_idx = i;
}
}
temp = arr[0];
arr[0] = arr[min_idx];
arr[min_idx] = temp;
temp = arr[n-1];
arr[n-1] = arr[max_idx];
arr[max_idx] = temp;
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
return 0;
}
```
程序中,首先读入整数序列的长度 `n`,然后定义长度为 `n` 的整型数组 `arr`。接着通过循环读入整数序列,并且找到序列中的最小值和最大值的索引。然后将最小值与第一个数交换,将最大值与最后一个数交换。最后通过循环输出交换后的序列。
阅读全文