2019陕西省赛J Coolbits
  YdxfFsjpYokY 2023年11月02日 70 0


也许更好的阅读体验

2019陕西省赛J Coolbits_c++
2019陕西省赛J Coolbits_acm_02个区间,需要在每个区间选一个数,使得将这些数与起来的结果最大,2019陕西省赛J Coolbits_acm_02个区间相互独立(即可选择相同的数)

2019陕西省赛J Coolbits_贪心算法_04
从大到小考虑每一位是否能填2019陕西省赛J Coolbits_acm_05 ,同时构造出每个区间选的数是什么
2019陕西省赛J Coolbits_c++_06 表示第2019陕西省赛J Coolbits_c++_07 个区间在满足之前贪心的条件下,目前选的数是什么,现在考虑到第2019陕西省赛J Coolbits_oi_08位了,假设第2019陕西省赛J Coolbits_oi_08 位为2019陕西省赛J Coolbits_acm_05 ,则2019陕西省赛J Coolbits_c++_06 会变成2019陕西省赛J Coolbits_贪心算法_12 ,之后能表达的数在区间2019陕西省赛J Coolbits_c++_13范围内
如果这个区间和2019陕西省赛J Coolbits_算法_14有交集,则说明第2019陕西省赛J Coolbits_c++_07 个区间在满足前面位的情况下第2019陕西省赛J Coolbits_oi_08 位可以为2019陕西省赛J Coolbits_acm_05 ,若所有区间第2019陕西省赛J Coolbits_oi_08 位都可为2019陕西省赛J Coolbits_acm_05 ,那么所有的2019陕西省赛J Coolbits_c++_20 ,否则就要考虑2019陕西省赛J Coolbits_c++_062019陕西省赛J Coolbits_oi_08 位是否为2019陕西省赛J Coolbits_acm_05
若本就不可为2019陕西省赛J Coolbits_acm_05 自不必说,而如果2019陕西省赛J Coolbits_c++_062019陕西省赛J Coolbits_oi_08 位可以为2019陕西省赛J Coolbits_acm_05 ,也可不为2019陕西省赛J Coolbits_acm_05 ,我们可以考虑设之前说的区间为2019陕西省赛J Coolbits_算法_29 ,现在我们其实并不关心第2019陕西省赛J Coolbits_oi_08 位如何,为2019陕西省赛J Coolbits_acm_05 也好,不为2019陕西省赛J Coolbits_acm_05 也好,只要能让我们在考虑之后的某位能为2019陕西省赛J Coolbits_acm_05 时能尽可能满足条件即可
此时需要注意到,考虑2019陕西省赛J Coolbits_acm_34 的二进制是什么样的,2019陕西省赛J Coolbits_贪心算法_35 ,也就是说,2019陕西省赛J Coolbits_acm_34 的第2019陕西省赛J Coolbits_oi_37 位到第2019陕西省赛J Coolbits_贪心算法_38 位都是2019陕西省赛J Coolbits_acm_05 ,如果我们的区间2019陕西省赛J Coolbits_算法_14 包含了2019陕西省赛J Coolbits_acm_34 ,那么第2019陕西省赛J Coolbits_oi_08 位不需要变成2019陕西省赛J Coolbits_acm_05 ,否则就只能为2019陕西省赛J Coolbits_acm_05

2019陕西省赛J Coolbits_acm_45

#include <cstdio>
using namespace std;
const int maxn = 1e5 + 10;
int T, n;
int l[maxn], r[maxn], now[maxn];
int main ()
{
    scanf("%d", &T);
while (T--) {
    scanf("%d", &n);
    for (int i = 1; i <= n; ++i)    scanf("%d%d", &l[i], &r[i]), now[i] = 0;
    int ans = 0;
    for (int i = 29; i >= 0; --i) {
        bool flag = true;
        for (int j = 1; j <= n && flag; ++j) {
            int nl = now[j] | (1 << i), nr = now[j] | ((2 << i) - 1);
            if (nl > r[j] || nr < l[j])   flag = false;
        }
        if (flag) {
            for (int j = 1; j <= n; ++j)    now[j] |= 1 << i;
            ans |= 1 << i;
        }
        else {
            for (int j = 1; j <= n; ++j) {
                int nl = now[j] | (1 << i), nr = now[j] | ((2 << i) - 1);
                if (nl <= r[j] && nr >= l[j] && nl - 1 <= l[j]) now[j] |= 1 << i;
            }
        }
    }
    printf("%d\n", ans);
}
    return 0;
}

如有哪里讲得不是很明白或是有错误,欢迎指正
如您喜欢的话不妨点个赞收藏一下吧


【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月08日 0

暂无评论

推荐阅读
  8Tw5Riv1mGFK   2024年05月01日   80   0   0 C++
  BYaHC1OPAeY4   2024年05月08日   56   0   0 C++
  yZdUbUDB8h5t   2024年04月29日   59   0   0 C++
  yZdUbUDB8h5t   2024年05月05日   43   0   0 C++
  oXKBKZoQY2lx   2024年05月17日   57   0   0 C++
YdxfFsjpYokY