题意

题目链接

Sol

线性基+线段树分治板子题。。

调起来有点自闭。。

#include<bits/stdc++.h>
#define fi first
#define se second
#define pb push_back
#define bit bitset<B + 1>
using namespace std;
const int MAXN = 501, B = 1001, SS = 4001;
inline int read() {
char c = getchar(); int x = 0, f = 1;
while(c < '0' || c > '9') {if(c == '-') f = -1; c = getchar();}
while(c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
return x * f;
}
int N, M, Q, las[SS];
struct Graph {
struct Edge {
int u, v;
bit w;
int nxt;
}E[3021];
int head[MAXN], num, vis[MAXN];
Graph() {
memset(head, -1, sizeof(head));
memset(vis, 0, sizeof(vis));
num = 0;
}
bit P[B + 1], dis[MAXN];
void insert(bit s) {
for(int i = B; ~i; i--) {
if(s[i]) {
if(!P[i].count()) {P[i] = s; break;}
s = s ^ P[i];
}
}
}
void dfs(int x, int fa) {
vis[x] = 1;
for(int i = head[x]; ~i; i = E[i].nxt) {
int to = E[i].v; bit w = E[i].w;
if((i ^ 1) == fa) continue;
if(vis[to]) insert(dis[x] ^ dis[to] ^ w);
else {
dis[to] = dis[x] ^ w;
dfs(to, i);
}
}
}
void Query() {
bit ans; ans.reset();
for(int i = B; ~i; i--) if(ans[i] ^ (P[i][i])) ans ^= P[i];
for(int i = B; ~i; i--)
if(ans[i]) {
for(int j = i; ~j; j--) cout << ans[j];
puts("");
return ;
}
puts("0");
}
void AddEdge(int x, int y, bit w) {
E[num] = {x, y, w, head[x]};
head[x] =num++;
}
void Insert(int x, int y, bit w) {
insert(dis[x] ^ dis[y] ^ w);
} }bg;
struct Edge {
int u, v;
bit w;
}e[SS];
vector<Edge> tag[SS]; #define ls k << 1
#define rs k << 1 | 1
void Add(int k, int l, int r, int ql, int qr, Edge v) {
if(ql > qr) return ;
if(ql <= l && r <= qr) {tag[k].pb(v); return ;}
int mid = l + r >> 1;
if(ql <= mid) Add(ls, l, mid, ql, qr, v);
if(qr > mid) Add(rs, mid + 1, r, ql, qr, v);
}
void Down(int k, int l, int r, Graph now) {
if(l > r) return ;
Graph nxt = now;
for(auto flag: tag[k])
nxt.Insert(flag.u, flag.v, flag.w);
if(l == r) {
nxt.Query();
return ;
}
int mid = l + r >> 1;
Down(ls, l, mid, nxt);
Down(rs, mid + 1, r, nxt);
}
signed main() {
N = read(); M = read(); Q = read();
for(int i = 1; i <= M; i++) {
int x = read(), y = read(); bit w; cin >> w;
bg.AddEdge(x, y, w);
bg.AddEdge(y, x, w);
}
memset(las, -1, sizeof(las));
int youducuotile = 0;
for(int i = 1; i <= Q; i++) {
char opt[10]; scanf("%s", opt + 1);
if(opt[1] == 'A') {
e[++youducuotile ].u = read(), e[youducuotile ].v = read();
cin >> e[youducuotile ].w; las[youducuotile ] = i;
} else if(opt[1] == 'C' && opt[2] == 'a') {
int k = read();
Add(1, 1, Q, las[k], i - 1, e[k]);
las[k] = -1;
} else {
int k = read();
Add(1, 1, Q, las[k], i - 1, e[k]);
cin >> e[k].w;
las[k] = i;
}
}
for(int i = 1; i <= Q; i++)
if(~las[i])
Add(1, 1, Q, las[i], Q, e[i]);
bg.dfs(1, -1);
bg.Query();
if(Q)
Down(1, 1, Q, bg);
return 0;
}

loj#2312. 「HAOI2017」八纵八横(线性基 线段树分治)的更多相关文章

  1. 洛谷.3733.[HAOI2017]八纵八横(线性基 线段树分治 bitset)

    LOJ 洛谷 最基本的思路同BZOJ2115 Xor,将图中所有环的异或和插入线性基,求一下线性基中数的异或最大值. 用bitset优化一下,暴力的复杂度是\(O(\frac{qmL^2}{w})\) ...

  2. LOJ 2302 「NOI2017」整数——压位线段树

    题目:https://loj.ac/problem/2302 压30位,a最多落在两个位置上,拆成两次操作. 该位置加了 a 之后,如果要进位或者借位,查询一下连续一段 0 / 1 ,修改掉,再在含有 ...

  3. 【LOJ】#3109. 「TJOI2019」甲苯先生的线段树

    LOJ#3109. 「TJOI2019」甲苯先生的线段树 发现如果枚举路径两边的长度的话,如果根节点的值是$x$,左边走了$l$,右边走了$r$ 肯定答案会是$(2^{l + 1} + 2^{r + ...

  4. LOJ 2312(洛谷 3733) 「HAOI2017」八纵八横——线段树分治+线性基+bitset

    题目:https://loj.ac/problem/2312 https://www.luogu.org/problemnew/show/P3733 原本以为要线段树分治+LCT,查了查发现环上的值直 ...

  5. LOJ2312 LUOGU-P3733「HAOI2017」八纵八横 (异或线性基、生成树、线段树分治)

    八纵八横 题目描述 Anihc国有n个城市,这n个城市从1~n编号,1号城市为首都.城市间初始时有m条高速公路,每条高速公路都有一个非负整数的经济影响因子,每条高速公路的两端都是城市(可能两端是同一个 ...

  6. loj#2483. 「CEOI2017」Building Bridges 斜率优化 cdq分治

    loj#2483. 「CEOI2017」Building Bridges 链接 https://loj.ac/problem/2483 思路 \[f[i]=f[j]+(h[i]-h[j])^2+(su ...

  7. ACM-ICPC 2017 Asia Xi'an A XOR (线性基+线段树思想)

    题目链接 题意;给个数组,每次询问一个区间你可以挑任意个数的数字异或和 然后在或上k的最大值 题解:线性基不知道的先看这个,一个线性基可以log的求最大值把对应去区间的线性基求出来然后用线段树维护线性 ...

  8. P5607-[Ynoi2013]无力回天NOI2017【线性基,线段树,树状数组】

    正题 题目链接:https://www.luogu.com.cn/problem/P5607 题目大意 \(n\)个数字的序列,\(m\)次操作 区间\([l,r]\)异或上一个值\(v\) 询问区间 ...

  9. LOJ 3055 「HNOI2019」JOJO—— kmp自动机+主席树

    题目:https://loj.ac/problem/3055 先写了暴力.本来想的是 n<=300 的那个在树上暴力维护好整个字符串, x=1 的那个用主席树维护好字符串和 nxt 数组.但 x ...

随机推荐

  1. ASP.NET Core 实战:基于 Jwt Token 的权限控制全揭露

    一.前言 在涉及到后端项目的开发中,如何实现对于用户权限的管控是需要我们首先考虑的,在实际开发过程中,我们可能会运用一些已经成熟的解决方案帮助我们实现这一功能,而在 Grapefruit.VuCore ...

  2. 游戏服务器h2engine架构优化和跨平台设计

    H2engine的GitHub星星不知不觉已经破百了,也没有特意推广过,但是慢慢的关注的人越来越多.因为事情多,好久没有写东西了,前一段时间有了一些想法,把h2engine又更新了一下,感觉h2eng ...

  3. 【响应式编程的思维艺术】 (5)Angular中Rxjs的应用示例

    目录 一. 划重点 二. Angular应用中的Http请求 三. 使用Rxjs构建Http请求结果的处理管道 3.1 基本示例 3.2 常见的操作符 四. 冷热Observable的两种典型场景 4 ...

  4. 简述private,protected,public,internal修饰符的访问权限

    private:私有成员,在类的内部才可以访问 protected:保护成员,在类的内部和继承类中可以访问 public:公共成员,完全公开,没有访问限制 internal:当前程序集内可以访问

  5. .net之设计模式

    在上一篇文章里我通过具体场景总结了“.net面向对象的设计原则”,其中也多次提到一些设计模式方面的技术,可想而知,设计模式在我们的开发过程中也是必不可少的.今天我们就来简单交流下设计模式.对于设计模式 ...

  6. 持续集成之 Nuget 进阶

    持续集成之 Nuget 进阶 Intro 之前介绍了一篇基于 Azure pipeline 的 nuget 包的持续集成配置,但是比较粗糙,这里介绍一下结合 Cake 实现更优雅的 nuget 包发布 ...

  7. DataPipeline联合Confluent Kafka Meetup上海站

    Confluent作为国际数据“流”处理技术领先者,提供实时数据处理解决方案,在市场上拥有大量企业客户,帮助企业轻松访问各类数据.DataPipeline作为国内首家原生支持Kafka解决方案的“iP ...

  8. [20190402]关于semtimedop函数调用2.txt

    [20190402]关于semtimedop函数调用2.txt --//前几天做了sql语句在mutexes上的探究.今天看看_mutex_wait_time设置很大的情况下是否semtimedop会 ...

  9. 微信小程序 写一个获取验证码 及setInterval 使用基本方法

    <!--index.wxml--> <view class="container"> <view class="container_cont ...

  10. 一分钟上手artTemplate

    一分钟上手artTemplate artTemplate是腾讯开源的前端模版引擎.之前做hue二次开发,只接触过用python写的mako模版引擎,所以之前对前端模版引擎了解不是很多. 这次因为pm叫 ...