D. 2+ doors(构造 二分图) CF 1715D
题目:
现在有一个长度为n的序列待构造,给出m对关系
分析:
每当我们看到最小字典序的时候,基本都是贪心的思想。本题可以知道,我们要让序列前面的数尽可能的小。对于他给出的关系,需要按位来考虑,但是有一些麻烦的就是你确定一个数的一位的时候,他会影响到与他有关系的数,感觉就是一个二分图的思想。我们可以用
实现:
对于给出的关系 若x在第
#include <bits/stdc++.h>
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<int, int> 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<int> 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';
}
分类:
CodeForces
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通