CCF 201903-1 小中大
题目
一开始拿到题目,哇简单啊!最大最小值就在两端产生,中间值必是中间的一个或两个数产生,再分情况算一下,小数的就四舍五入保留1位小数,四舍五入简单啊,把他扩大再搞就好了,然后哗哗哗一通写下来,写了一堆bug……
虽然100但十分繁杂的代码
#include <iostream>
#include <bits/stdc++.h>
#include <vector>
using namespace std;
vector<int> nums;
int abs(int n){
return n>=0?n:-n;
}
int main()
{
int n;
cin>>n;
for(int i=0;i<n;i++){
int a;
cin>>a;
nums.push_back(a);
}
int mid,m1,m2,m3,type;
if(n%2==0){
int a=nums[n/2-1]+nums[n/2];
if(a%2==0){
type=1;
mid=a/2;
}else{
type=0;
int b=a*50;
// bug1给的数可能是负数,因此在计算第二、第三小数位的时候要先取绝对值
m3=abs(b)%10;
m2=abs(b)/10%10;
m1=b/100;
if(m3>=5){
m2++;
}
if(m2>=10){
m1+=m2/10;
m2%=10;
}
}
}else{
// bug2:n是奇数的情况也要给人家设置type
type=1;
mid=nums[n/2];
}
int maxx=nums[0]>=nums[n-1]?nums[0]:nums[n-1];
int minn=nums[0]<=nums[n-1]?nums[0]:nums[n-1];
if(type){
cout<<maxx<<" "<<mid<<" "<<minn;
}else{
cout<<maxx<<" "<<m1<<"."<<m2<<" "<<minn;
}
return 0;
}
// 总之就是非常长也没必要……
稍微稍微思考一下,给的都是整数,两个整数相加除以2只会出现两种情况,要么是整数,要么就是带0.5的,也就是说根本不用考虑什么四舍五入保留一位小数,小数位只能是5,所以前面一大堆四舍五入的计算根本没有必要!!!!
代码
#include <iostream>
#include <bits/stdc++.h>
#include <vector>
using namespace std;
vector<int> nums;
int abs(int n){
return n>=0?n:-n;
}
int main()
{
int n;
cin>>n;
for(int i=0;i<n;i++){
int a;
cin>>a;
nums.push_back(a);
}
int maxx,minn;
if(nums[0]>=nums[n-1]){
maxx=nums[0];
minn=nums[n-1];
}else{
maxx=nums[n-1];
minn=nums[0];
}
cout<<maxx<<" ";
if(n%2==0){
int a=nums[n/2-1]+nums[n/2];
if(a%2==0)
cout<<a/2<<" ";
else{
printf("%.1lf ",a/2.0);
}
}else{
cout<<nums[n/2]<<" ";
}
cout<<minn;
return 0;
}