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;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值