SPOJ QTREE4 lct
这个题已经处于花式tle了,改版后的spoj更慢了。。
tle的话就多交几把。。。
#include <iostream>
#include <fstream>
#include <string>
#include <time.h>
#include <vector>
#include <map>
#include <queue>
#include <algorithm>
#include <stack>
#include <cstring>
#include <cmath>
#include <set>
#include <vector>
using namespace std;
template <class T>
inline bool rd(T &ret) {
char c; int sgn;
if (c = getchar(), c == EOF) return 0;
while (c != '-' && (c<'0' || c>'9')) c = getchar();
sgn = (c == '-') ? -1 : 1;
ret = (c == '-') ? 0 : (c - '0');
while (c = getchar(), c >= '0'&&c <= '9') ret = ret * 10 + (c - '0');
ret *= sgn;
return 1;
}
template <class T>
inline void pt(T x) {
if (x < 0) {
putchar('-');
x = -x;
}
if (x > 9) pt(x / 10);
putchar(x % 10 + '0');
}
typedef long long ll;
typedef pair<int, int> pii;
const int N = 200000 + 10;
const int inf = 1e9;
struct Node *null;
inline int First(multiset<int>&x) {//返回x中最大的数
return *x.rbegin();
}
inline int Second(multiset<int>&x) {//返回x中次大的数
multiset<int>::reverse_iterator it = x.rbegin();
it++; return *it;
}
struct Node {
Node *fa, *ch[2];
int size;
multiset<int>path, chain;
int ls, rs, ms;
int col, len, id;
bool rev;
inline void put() {
printf("%d siz:%d len:%d (%d,%d,%d) son{%d,%d} fa:%d col:%d \n", id, size, len, ls, rs, ms, ch[0]->id, ch[1]->id, fa->id, col);
// cout << "path: ";for (auto i : path)cout << i << " ";puts("");
// cout << "chain:";for (auto i : chain)cout << i << " ";puts("");
}
inline void clear(int _col, int _id) {
fa = ch[0] = ch[1] = null;
rev = 0;
id = _id;
col = _col;
size = len = 0;
ls = rs = ms = -inf;
path.clear(); chain.clear();
chain.insert(-inf); chain.insert(-inf); path.insert(-inf);
}
inline void push_up() {
if (this == null)return;
size = len + ch[0]->size + ch[1]->size;
int _chain = max(col, First(chain));
int L = max(_chain, ch[0]->rs + len);//从(虚边 or 左子树)的白点到this的最远距离
int R = max(_chain, ch[1]->ls);//从(虚边 or 右子树)的白点到this的最远距离
ls = max(ch[0]->ls, ch[0]->size + len + R);
rs = max(ch[1]->rs, ch[1]->size + L); ms = max(ch[0]->rs + len + R, L + ch[1]->ls);
ms = max(ms, max(ch[0]->ms, ch[1]->ms));
ms = max(ms, First(path));
ms = max(ms, First(chain) + Second(chain));
if (col == 0)
ms = max(max(ms, First(chain)), 0);
}
inline void push_down() {
if (rev) {
ch[0]->flip();
ch[1]->flip();
rev = 0;
}
}
inline void setc(Node *p, int d) {
ch[d] = p;
p->fa = this;
}
inline bool d() {
return fa->ch[1] == this;
}
inline bool isroot() {
return fa == null || fa->ch[0] != this && fa->ch[1] != this;
}
inline void flip() {
if (this == null)return;
swap(ch[0], ch[1]);
rev ^= 1;
}
inline void go() {//从链头開始更新到this
if (!isroot())fa->go();
push_down();
}
inline void rot() {
Node *f = fa, *ff = fa->fa;
int c = d(), cc = fa->d();
f->setc(ch[!c], c);
this->setc(f, !c);
if (ff->ch[cc] == f)ff->setc(this, cc);
else this->fa = ff;
f->push_up();
}
inline Node*splay() {
// go();
while (!isroot()) {
if (!fa->isroot())
d() == fa->d() ? fa->rot() : rot();
rot();
}
push_up();
return this;
}
inline Node* access() {//access后this就是到根的一条splay,而且this已经是这个splay的根了
for (Node *p = this, *q = null; p != null; q = p, p = p->fa) {
p->splay();
if (p->ch[1] != null) {
p->chain.insert(p->ch[1]->ls);
p->path.insert(p->ch[1]->ms);
}
if (q != null) {
p->chain.erase(p->chain.find(q->ls));
p->path.erase(p->path.find(q->ms));
}
p->setc(q, 1);
p->push_up();
}
return splay();
}
inline Node* find_root() {
Node *x;
for (x = access(); x->push_down(), x->ch[0] != null; x = x->ch[0]);
return x;
}
void make_root() {
access()->flip();
}
void cut() {//把这个点的子树脱离出去
access();
ch[0]->fa = null;
ch[0] = null;
push_up();
}
void cut(Node *x) {
if (this == x || find_root() != x->find_root())return;
else {
x->make_root();
cut();
}
}
void link(Node *x) {
if (find_root() == x->find_root())return;
else {
make_root(); fa = x;
}
}
};
void debug(Node *x) {
if (x == null)return;
x->put();
debug(x->ch[0]);
debug(x->ch[1]);
}
Node pool[N], *tail;
Node *node[N];
int n, q;
struct Edge {
int to, next, dis;
}edge[N<<1];
int head[N], edgenum;
inline void add(int u, int v, int dis) {
Edge E = { v, head[u], dis };
edge[edgenum] = E;
head[u] = edgenum++;
}
void dfs(int u, int fa) {
for (int i = head[u]; ~i; i = edge[i].next){
int v = edge[i].to; if (v == fa)continue;
node[v]->fa = node[u];
node[v]->len = edge[i].dis;
dfs(v, u);
node[u]->path.insert(node[v]->ms);
node[u]->chain.insert(node[v]->ls);
}
node[u]->push_up();
}
int main() {
while (cin >> n) {
tail = pool;
null = tail++;
null->clear(-inf, 0);
edgenum = 0;
for (int i = 1; i <= n; i++) {
head[i] = -1;
node[i] = tail++;
node[i]->clear(0, i);
}
for (int i = 1, u, v, d; i < n; i++) {
rd(u); rd(v); rd(d);
add(u, v, d); add(v, u, d);
}
dfs(1, 1);
rd(q); char str[5]; int u;
int ans = node[1]->ms;
while (q--) {
scanf("%s", str);
if (str[0] == 'C') {
rd(u);
node[u]->access();
if (node[u]->col == 0)node[u]->col = -inf;
else node[u]->col = 0;
node[u]->push_up();
ans = node[u]->ms;
}
else {
if (ans < 0)puts("They have disappeared.");
else pt(ans), puts("");
}
// for (int i = 1; i <= n; i++)debug(node[i]), puts("");
}
}
return 0;
}
/* */
SPOJ QTREE4 lct的更多相关文章
- SPOJ - OTOCI LCT
		OTOCI Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudge/problem/viewProblem. ... 
- SPOJ QTREE3 lct
		题目链接 题意: 给定n个点 q个询问 以下n-1行给出树边,点有黑或白色.初始化为白色 以下q行: 询问有2种: 1. 0 x 把x点黑变白,白变黑 2.1 x 询问Path(1,x)路径上第一个黑 ... 
- SPOJ QTREE4 SPOJ Query on a tree IV
		You are given a tree (an acyclic undirected connected graph) with N nodes, and nodes numbered 1,2,3. ... 
- SPOJ QTREE2 lct
		题目链接 题意: 给一棵树.有边权 1.询问路径的边权和 2.询问沿着路径的第k个点标. 思路:lct裸题. #include <iostream> #include <fstrea ... 
- SPOJ QTREE5 lct
		题目链接 对于每一个节点,记录这个节点所在链的信息: ls:(链的上端点)距离链内部近期的白点距离 rs:(链的下端点)距离链内部近期的白点距离 注意以上都是实边 虚边的信息用一个set维护. set ... 
- SPOJ QTREE4 - Query on a tree IV 树分治
		题意: 给出一棵边带权的树,初始树上所有节点都是白色. 有两种操作: C x,改变节点x的颜色,即白变黑,黑变白 A,询问树中最远的两个白色节点的距离,这两个白色节点可以重合(此时距离为0). 分析: ... 
- SPOJ QTREE4 - Query on a tree IV
		You are given a tree (an acyclic undirected connected graph) with N nodes, and nodes numbered 1,2,3. ... 
- SPOJ QTREE4 Query on a tree IV ——动态点分治
		[题目分析] 同bzoj1095 然后WA掉了. 发现有负权边,只好把rmq的方式改掉. 然后T了. 需要进行底(ka)层(chang)优(shu)化. 然后还是T 下午又交就A了. [代码] #in ... 
- Query on a tree IV SPOJ - QTREE4
		https://vjudge.net/problem/SPOJ-QTREE4 点分就没有一道不卡常的? 卡常记录: 1.把multiset换成手写的带删除堆(套用pq)(作用很大) 2.把带删除堆里面 ... 
随机推荐
- Python urllib和urllib2模块学习(二)
			一.urllib其它函数 前面介绍了 urllib 模块,以及它常用的 urlopen() 和 urlretrieve()函数的使用介绍.当然 urllib 还有一些其它很有用的辅助方法,比如对 ur ... 
- 论山寨手机与Android 【14】3G SmartPhone时代的MTK
			分析了SmartPhone的里里外外以后,现在我们可以分析MTK的机遇和挑战了.MTK面临的外部环境在发生变化,变化有两条,一是移动网络从2G演变到3G,二是手机由FeaturePhone演化到Sma ... 
- java 多线程使用方法及Socket的使用
			public class newThread implements Runnable{ public void run(){ dosome(); } public void dosome(){ Sys ... 
- Hibernate 多表关联映射-   一对多关系映射(one-to-many)
			Hibernage.cfg.xml: <hibernate-configuration> <session-factory name="sessionFactory&quo ... 
- linux系统的性能问题排除分析
			需要结合sar和top进行检查. top下关注load,%wa,%idle等 sar -u -o cpureport 10 3 每10秒采集3次 放在同目录下的文件cpureport 里 检查io s ... 
- VB.NET的反射机制
			1.前提 Net的应用程序由几个部分:‘程序集’.‘模块’.‘类型’组成. 装配件是.Net应用程序执行的最小单位,编译出来的.dll..exe都是装配件. 2.概念 反射是获得运行时类型的方式. 概 ... 
- 自己动手写CPU之第五阶段(3)——MIPS指令集中的逻辑、移位与空指令
			将陆续上传本人写的新书<自己动手写CPU>(尚未出版),今天是第17篇.我尽量每周四篇 5.4 逻辑.移位操作与空指令说明 MIPS32指令集架构中定义的逻辑操作指令有8条:and.and ... 
- C# 中4个访问符和8个修饰符详解
			4个访问修饰符(是添加到类.结构或成员声明的关键字) Public:公有的,是类型和类型成员的访问修饰符.对其访问没有限制. Internal:内部的,是类型和类型成员的访问修饰符.同一个程序集中的所 ... 
- 关于css3中before与after用单冒号还是双冒号的疑虑
			在 CSS3 中为了区别伪元素和伪类为伪元素使用了双冒号,因此如果使用了 display 或者 width 等属性时使得显示脱离了原本元素后,建议按照标准双写. 
- sql日志损坏造成数据库置疑解决办法
			--如果确定是日志损坏造成,请用下面的方法恢复日志文件.--第一步--use mastergo sp_configure 'allow updates', 1reconfigure with over ... 
