D. 2+ doors(构造 二分图) CF 1715D

题目:

​ 现在有一个长度为n的序列待构造,给出m对关系(i, j,x),表示(a_i|a_j=x),请在满足这m对关系的情况下构造出的最小字典序的序列。

分析:

​ 每当我们看到最小字典序的时候,基本都是贪心的思想。本题可以知道,我们要让序列前面的数尽可能的小。对于他给出的关系,需要按位来考虑,但是有一些麻烦的就是你确定一个数的一位的时候,他会影响到与他有关系的数,感觉就是一个二分图的思想。我们可以用(f0[i][j])表示第(i)个数在第(j)位必定填0,(f1[i][j])同理必定填1。顺序遍历序列,枚举位,能填0就填0。

实现:

​ 对于给出的关系 若x在第(k)位上为0,那么(i)和(j)在第k位上都必须填0,若x在第(k)位上为1,那么(i)和(j)在第k位上至少要有一个人是1。同时不能忽略(i=j)的情况,若(i==j)且x在第(k)位上为1,那么(i)在第k位上必须填1。那么现在我们预处理出了必须填的情况,但是还有一种情况我们是不能确定的,就是当某位可以填0或者填1的时候,怎么办?基于贪心的思想,肯定是填0最好,但是不一定能填上。为什么?因为如果你这一位填0,那么和他有关的那个数的这一位必须就填1,所以要在合法的情况下,才能填上0。这就是用到了二分图的思想,实现上我们将这种模糊的关系连一条边,对于当前(a_i)决定要填0的时候,遍历一下,若目标数在该位上必须填0,那么我当前(a_i)就只能填1了,因为模糊的优先级是不如必定的。

#include

using namespace std;
#define rep(i, a, n) for(int i = a; i < n; i++)
#define all(x) x.begin(), x.end()
#define pb push_back
#define ios ios::sync_with_stdio(false);cin.tie(0);
#define debug(x)    cout << x << endl;
#define SZ(x)    (int)x.size()
typedef long long LL;
typedef unsigned long long ULL;
typedef pair PII;
const int inf = 0x3f3f3f3f;
void read(int &x) {int s = 0, f = 1; char ch = getchar(); while(!isdigit(ch)) {f = (ch == '-' ? -1 : f); ch = getchar();} while(isdigit(ch)) {s = s * 10 + ch - '0'; ch = getchar();} x = s * f;}

const int N = 100005;
int n, m;
vector g[N][30];
int f0[N][30], f1[N][30]; //第i个数的第j位必须填0或者必须填1

signed main()
{
    cin >> n >> m;
    rep(i, 1, m + 1)
    {
        int u, v, c;
        cin >> u >> v >> c;
        if(u > v)   swap(u, v);
        for(int j = 29; j >= 0; j --)
        {
            if(c >> j & 1)
            {
                if(u == v)
                    f1[u][j] = f1[v][j] = 1;
                else
                    g[u][j].push_back(v);
            }
            else
                f0[u][j] = f0[v][j] = 1;
        }
    }

    rep(i, 1, n + 1)
    {
        int res = 0;
        for(int j = 29; j >= 0; j --)
        {
            bool can0 = 1;
            if(f1[i][j])
                can0 = 0;
            else if(!f1[i][j] && !f0[i][j])
            {
                for(int v : g[i][j])
                    if(f0[v][j])
                        can0 = 0;
            }

            if(can0) //这位填0
                for(int v : g[i][j])
                    f1[v][j] = 1;
            else
                res += 1 << j;
        }
        cout << res << ' ';
    }
    cout << '\n';
}

Original: https://www.cnblogs.com/DM11/p/16649209.html
Author: DM11
Title: D. 2+ doors(构造 二分图) CF 1715D

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/604346/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • 线段树套线性基 P4839 P哥的桶

    线段树每个结点维护一个线性基,插入时直接插入,查询时把所有被查询区间所包含的区间的线性基插入到一个大的线性基里,最后在大的线性基里查询就好了。 (O(n\log m\log ^2x…

    数据结构和算法 2023年6月12日
    074
  • 最长公共子序列

    题目链接 P1439LIS(Longest Increasing Subsequence)(最长递增子序列)LCS(Longest Common Subsequence)(最长公共…

    数据结构和算法 2023年6月12日
    073
  • 有序数组构造平衡树 1、因为是有序数组,所以我们要取数组中间的数作为根节点2、接下来我们可以将数组分成左右两块3、根的左节点为左边的数组的中间的值,而根的右节点为右边数组的中间的值…

    数据结构和算法 2023年6月7日
    095
  • 1054 The Dominant Color (20 分)

    1. 题目 Behind the scenes in the computer’s memory, color is always talked about as a …

    数据结构和算法 2023年6月7日
    061
  • 力扣算法JS LC [55. 跳跃游戏] LC [45. 跳跃游戏 II]

    给定一个非负整数数组 nums ,你最初位于数组的 第一个下标 。 数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个下标。 示例 1: 输入:nums…

    数据结构和算法 2023年6月12日
    075
  • 深度学习——正则化

    深度学习——正则化 作者:Oto_G 全是自我理解,表达不严谨,仅供参考 本文默认正则化范数为L1范数 这是今天讨论的问题: 为什么融入正则的损失函数能够防止过拟合 为什么正则融入…

    数据结构和算法 2023年6月12日
    0111
  • 数据结构 1

    莫队的重学。 普通莫队的排序有很多讲究,以后只写回滚莫队好了,至少复杂度是稳定的。这是莫队的排序关键字:((\textit{bel}_{ \text{left endpoint }…

    数据结构和算法 2023年6月12日
    091
  • 单例模式

    使用最广同时也是面试问的最多的一个设计模式 代码: 还有一种方式:静态局部变量实现的懒汉式,且线程安全的模式。 某天面试被问到单例模式有什么缺点,没了解过,只是说优点还是蛮多的。 …

    数据结构和算法 2023年6月8日
    084
  • jarvis OJ-DSA

    下载附件后,打开来为四个签名文件、被签名的信息以及一份pem形式的公钥 题目提示说此题的攻击方式曾被用于PS3的破解。 首先了解一下DSA的签名以及验证的过程。 在签名和验证之前,…

    数据结构和算法 2023年6月7日
    071
  • 剑指 Offer 14- II. 剪绳子 II

    剑指 Offer 14- II. 剪绳子 II 这里需要注意到数据范围已经从Ⅰ的1-58更新至1000,且需要对1e9+7取模运算,所以这里已经不能再使用dp了,因为dp需要使用m…

    数据结构和算法 2023年6月7日
    0101
  • 【AcWing】第 63 场周赛 【2022.08.06】

    请计算,共有多少个整数数对 (x,y) 同时满足: 例如,当 a=5,b=6,n=3 时,共有 4 个满足条件的数对: (0,3),(1,2),(2,1),(3,0)。 第一行包含…

    数据结构和算法 2023年6月8日
    080
  • MySQL建表语句生成Golang代码

    1. 背景 对于后台开发新的需求时,一般会先进行各种表的设计,写各个表的建表语句 然后根据建立的表,写对应的model代码、基础的增删改查代码(基础的增删改查服务可以划入DAO(D…

    数据结构和算法 2023年6月8日
    076
  • 并查集详解 图解引入到实现| Disjoint Sets details, intro to implementation with figures.

    Introduction of Disjoint Sets It’s easy to tell whether someone you know is your rel…

    数据结构和算法 2023年6月16日
    098
  • 近期的刷题计划

    最近打算按照一些专题来刷,初步定调为图论、构造题、与dp。但主要还是按照比赛刷题。 Original: https://www.cnblogs.com/johnsonstar/p/…

    数据结构和算法 2023年6月7日
    080
  • 力扣55. 跳跃游戏

    55.跳跃游戏 数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个下标。 示例 1: 输入:nums = [2,3,1,1,4]输出:true解释:可以…

    数据结构和算法 2023年6月16日
    0132
  • 【题解】[CSP-S2019] 格雷码

    题目描述 通常,人们习惯将所有 (n) 位二进制串按照字典序排列,例如所有 2 位二进制串按字典序从小到大排列为:00,01,10,11。 格雷码(Gray Code)是一种特殊的…

    数据结构和算法 2023年6月12日
    0108
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球