【每日一题】5月20日 简单瞎搞题

简单瞎搞题

https://ac.nowcoder.com/acm/problem/17193

一共有 n个数,第 i 个数是 xi
 xi 可以取 中任意的一个值。
图片说明 ,求 S 种类数。

分析:分组背包问题,图片说明的值表示前i个数是否能表示j, 我们要求最后能表示的数的种类数,就是求
图片说明 .
考虑每一个dp状态只有两种0和1.那么我们可以用bitset优化背包,将第二维的值变成二进制下1的位置.那么转移状态:
图片说明 .
那么最后的答案就是图片说明 的1的个数,直接调用count()计算即可。
另外附一题同样的bitset背包优化的题.

https://ac.nowcoder.com/acm/contest/4912/C
题解暂时鸽了

#include<bits/stdc++.h>
using namespace std;

const int maxn=1e6+10;

bitset<maxn> dp[102];
int n;

int main()
{
    scanf("%d",&n);dp[0].set(0);
    for( int i=1;i<=n;i++ )
    {
        int l,r;scanf("%d%d",&l,&r);
        for(int j=l;j<=r;j++ ) dp[i] |= (dp[i-1]<<(j*j));
    }
    printf("%d\n",dp[n].count());
}
每日一题 文章被收录于专栏

每日一题

全部评论

相关推荐

ProMonkey2024:5个oc?厉害! 但是有一个小问题:谁问你了?😡我的意思是,谁在意?我告诉你,根本没人问你,在我们之中0人问了你,我把所有问你的人都请来 party 了,到场人数是0个人,誰问你了?WHO ASKED?谁问汝矣?誰があなたに聞きましたか?누가 물어봤어?我爬上了珠穆朗玛峰也没找到谁问你了,我刚刚潜入了世界上最大的射电望远镜也没开到那个问你的人的盒,在找到谁问你之前我连癌症的解药都发明了出来,我开了最大距离渲染也没找到谁问你了我活在这个被辐射蹂躏了多年的破碎世界的坟墓里目睹全球核战争把人类文明毁灭也没见到谁问你了(别的帖子偷来的,现学现卖😋)
点赞 评论 收藏
分享
1 收藏 评论
分享
牛客网
牛客企业服务