512.0MB Python、C++版答案

系统 1797 0

刚看到这个题的时候以为10分钟就能做出来,但是还是有坑的,不小心的话总是无法全对,还是做了好一会儿。

先放C++版的答案,代码简洁,思路简单。

            
              #include
              
                
#include
                
                  

using namespace std;

int main()
{
    int Max,Min,n,flag=0;
    double Mid;
    cin>>n;
    int a[n];
    for(int i=0; i
                  
                    >a[i];
    }
    if(n%2)
       Mid = a[n/2];
    else
       Mid = (a[n/2]+a[n/2-1])/2.0;

    if(a[n-1] > a[0]){
        Max = a[n-1];
        Min = a[0];
    }else{
        Max = a[0];
        Min = a[n-1];
    }
    if(int(Mid) == Mid)
        cout<
                    
                      <<" "<
                      
                    
                  
                
              
            
          

有两个需要注意的地方,第一个是分数的输出格式,用setw()临时控制其后一个数据的输出(只控制Mid),第二个是输出中位数时,注意2.0这种数据的出现,用int(Mid)判断一下就好了。

 

用Python写就舒服多了,关键是变量的类型转换比较方便~

            
              n = int(input())
data = [int(i) for i in input().split()]

Max = max(data)
Min = min(data)
half = len(data) // 2
Mid = (data[half] + data[~half])/2 #这里Mid是浮点数

if(int(Mid) == Mid): 
    Mid = int(Mid)
print("{} {} {}".format(Max,Mid,Min))

            
          

运行速度还是蛮快的,但是耗内存比较多,幸好这道题数据量不大,比赛的时候需要谨慎使用~


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论