小菜鸡又来了

牛牛算数

https://ac.nowcoder.com/acm/contest/9556/A

今天的第一题我真的是很有思路,无奈能力有限,不能实现自己的想法

首先找中位数,我的理解就是直接先排序,然后分别从头和尾向中间进军,所得到的中位数就是头尾相加除2,这样完美包含了数组个数是偶数或者奇数的情况

计算平均数,单纯遍历,除掉数组长度

但是在比较的时候出现问题,因为设定的问题所以两个数的小数部分没有考虑进去,加了强制转换也不可以

先上直播的时候大佬的代码

class Solution {
public:
    /**
     * 
     * @param arr int整型vector 
     * @return int整型
     */
    int Answerofjudge(vector<int>& arr) {
        // write code here
       int i;
       double sum=0;
        for(i=0;i<arr.size();i++)
        {
            sum+=arr[i];
        }
        sort(arr.begin(),arr.end());
        double mid;
        if(arr.size()&1)mid=arr[arr.size()/2];
        else mid=(arr[arr.size()/2]+arr[arr.size()/2-1])/2.0;

        int x=-1;
        if(mid>sum/arr.size())
            x=1;
        else if(fabs(sum/arr.size()-mid)<1e-8)
           x=0;
        return x;
    }
};

这里面我注意到大佬的解法中判断数组长度是奇数还是偶数的时候,是通过与1,我将其改成除2取余,通过率就立即降到20%
在最后判断的时候大佬用了一个fabs也是我没见过的;

double fabs(double x );
功能:求浮点数x的绝对值
说明:计算|x|, 当x不为负时返回 x,否则返回 -x

表达式“n&1”表示的是n与1的按位与(其业务逻辑应该是:当且仅当n为奇数时结果为1,其余时候为0)
对于表达式”n==1“表示的是判断两整数是否相等(其业务逻辑是:当且仅当n为1时结果为true其余时候为false)

越努力,越幸运!

全部评论

相关推荐

投递海康威视等公司7个岗位
点赞 评论 收藏
转发
点赞 收藏 评论
分享
牛客网
牛客企业服务