牛客编程巅峰赛S2第11场

牛牛做水题

题目描述

牛牛喜欢做题。但他不喜欢做难题,喜欢做水题。
对于一个题号为的题而言,题目的难度为的所有因子之和除以。牛牛认为难度小于2的题目都是水题。
例如:
编号为25的题目,其难度为(1+5+25)/25=1.24<2,因此这道题是水题。
编号为28的题目,其难度为(1+2+4+7+14+28)/28=2,因此这道题不是水题。
编号为30的题目,其难度为(1+2+3+5+6+10+15+30)/30=2.4>2,因此这道题也不是水题。
牛牛拿到了一个共有道题目的题单,上面的题号为1、2、3、…、。牛牛把上面所有的水题刷了个遍。每做一道编号为的水题,牛牛可以获得的快乐指数。
牛牛想知道,自己一共能获得多少快乐指数?

示例1

输入

4

返回值

10

说明

题号为1到4的四道题都是水题,所以牛牛全部做了,快乐指数为1+2+3+4=10

示例2
输入

282

返回值

30101

备注:

1<=n<=1000;

暴力,其中找一个数的因数时,循环只用遍历到sqrt(i)就够了。
代码如下:

class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 返回牛牛获得的快乐指数
     * @param n int整型 题单里的题目数量
     * @return int整型
     */
    int doQuestion(int n) {
        // write code here
        int ans=0;
        double sum = 0;
        long long res[1005];
        res[0]=0;
        for(int i=1;i<=1000;i++){
            sum = 0;
            for(int j=1;j<sqrt(i);j++){
                if(i%j==0) sum += j,sum += i/j;
            }
            if(sqrt(i) == (int)sqrt(i)) sum += sqrt(i);
            sum /= i;
            if(sum < 2) {
                res[i] = res[i-1]+i;
            } else{
                res[i] = res[i-1];
            }
        }
        return res[n];
    }
};

牛牛浇树

题目描述

长度为n的数组初始全为0,每分钟数组元素的值都会自增1。
m次操作,每次选择一个区间,在自增的基础上额外增1
求m次操作后数组中奇数的个数

示例1
输入 >>3,2,[1,2],[2,3]
返回值

2

说明

第一分钟后 第一个数为2,第二个数为2,第三个数为1
第二分钟后 第一个数为3,第二个数为4,第三个数为3,一共两个数为奇数,所以输出2

备注:

函数共包含四个参数
第一个参数是一个int型参数n
第二个参数是一个int型参数m
第三个参数是一个共含有m个元素的vector型参数l
第四个参数是一个共含有m个元素的vector型参数r
对于100%的数据,1≤n≤2e5;1≤m≤2e5;1≤l[i]≤r[i]≤n

差分
在这里插入图片描述
代码如下:

class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     * 返回m天后高度为奇数的树的数量
     * @param n int整型 
     * @param m int整型 
     * @param l int整型vector 
     * @param r int整型vector 
     * @return int整型
     */
    int sum[200020]={0};
    int oddnumber(int n, int m, vector<int>& l, vector<int>& r) {
        // write code here
        int i;
        for(i=0;i<m;i++){
            sum[l[i]]++;
            sum[r[i]+1]--;
        }
        for(i=1;i<=n;i++){
            sum[i]=sum[i-1]+sum[i];
        }
        int res=0;
        for(i=1;i<=n;i++){
            if((sum[i]+m)%2==1) res++;
        }
        return res;
        
    }
};

挑选方案问题

题目描述

自助餐厅里有5个盘子,里面装的都是面包。
第1个盘子里有无限个面包;
第2个盘子里只有1个面包;
第3个盘子里只有4个面包;
第4个盘子里也有无限个面包,但必须两个两个地拿;
第5个盘子里也有无限个面包,但必须5个5个地拿;
给定正整数n,求有多少种正好拿出n个面包的方案。
方案a和方案b不同,当且仅当方案a存在从某个盘子里拿出面包的数量与方案b中对应盘子拿出的数量不同。

示例1
输入

1

返回值

3

说明

有3种方案:
在第一个盘子拿一个。
在第二个盘子拿一个。
在第三个盘子拿一个。

示例2
输入

2

返回值

6

说明

有6种方案:
在第一个盘子拿2个。
在第一个盘子拿1个,第二个盘子拿1个。
在第一个盘子拿1个,第三个盘子拿1个。
在第二个盘子拿1个,第三个盘子拿1个。
在第三个盘子拿2个。
在第四个盘子拿2个。
(请注意由于第四个盘子里只能两个两个拿,所以必须拿偶数个)

备注:

n<=10^9
数据仅包含一个正整数n
输出一个正整数表示答案。

代码如下:

class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     * 
     * @param n int整型 
     * @return long长整型
     */
    long long wwork(int n) {
        // write code here
        return 1LL*(1+n+1)*(n+1)/2;
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值