互换最大最小数

题目链接:https://www.nowcoder.com/practice/04c0f21530994fbfa94887f1e3588e6a?tpId=40&tqId=21488&tPage=8&rp=1&ru=%2Fta%2Fkaoyan&qru=%2Fta%2Fkaoyan%2Fquestion-ranking

题目描述

输入一个数n,然后输入n个数值各不相同,调换数组中最大和最小的两个数,然后输出。

输入描述:

测试数据有多组,输入n(1<=n<=20),接着输入n个数。

输出描述:

对于每组输入,输出交换后的结果。
示例1

输入

2
1 3

输出

3 1
 1 #include <iostream>
 2 #include <string>
 3 #include <cstring>
 4 #include <algorithm>
 5 #include <cmath>
 6 #include <stack>
 7 using namespace std;
 8 int a[100010];
 9 int main()
10 {
11     int n;
12     while(cin>>n){
13         if(n==1){
14             cin>>a[0];
15             cout<<a[0]<<endl;
16             continue;
17         }
18         for(int i=0;i<n;i++){
19             cin>>a[i];
20         }
21         int smax=a[0],smin=a[0];
22         int sm=0,sn=0;
23         for(int i=0;i<n;i++){
24             if(a[i]>smax){
25                 smax=a[i];
26                 sm=i;
27             }
28             if(a[i]<smin){
29                 smin=a[i];
30                 sn=i;
31             }
32         }
33         swap(a[sm],a[sn]);
34         for(int i=0;i<n-1;i++){
35             cout<<a[i]<<" ";
36         }
37         cout<<a[n-1]<<endl;
38     }
39     return 0;
40 }

 

转载于:https://www.cnblogs.com/shixinzei/p/8074373.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值