码迷,mamicode.com
首页 > 其他好文 > 详细

hahaha

时间:2018-10-26 19:47:13      阅读:156      评论:0      收藏:0      [点我收藏+]

标签:print   std   dfs序   get   ||   vector   dde   关系   lazy   

#include<cstdio>
#include<cstring>
#include<cctype>
#include<cstdlib>
#include<cmath>
#include<string>
#include<iostream>
#include<algorithm>
#include<set>
#include<map>
#include<queue>
#include<stack>
#include<vector>
#define enter puts("")
using namespace std;
typedef long long ll;
const int maxn = 5e4 + 5;
int head[maxn], tot, cnt, n, m, fa[maxn];//cnt表示节点个数 ,fa[]用于查找树根 
struct E
{
    int to, next, val;
}ed[maxn];//存储输入的关系图 
struct dfsid
{
    int lef, rig;
}bc[maxn];//存储dfs序,bc[i].lef表示i第一次出现的序号, bc[i].rig表示i第二次出现的序号 
struct Tree
{
    int data, upd;
}lj[maxn << 2];//存储线段树,data表示节点值,upd表示区间更新的lazy标记 
int read()
{
    int ans = 0, op = 1;
    char ch = getchar();
    while(ch < 0 || ch > 9)
    {
        if(ch == -) op = 0;
        ch = getchar();
    }
    while(ch >= 0 && ch <= 9)
    {
        ans *= 10;
        ans += ch - 0;
        ch = getchar();
    }
    return op ? ans : -ans;
}
void write(int x)
{
    if(x < 0)
    {
        x = -x;
        putchar(-);
    }
    if(x >= 10) write(x / 10);
    putchar(0 + x % 10);
}
void init()
{
    memset(head, -1, sizeof(head));
    memset(fa, -1, sizeof(fa));
    memset(lj, -1, sizeof(Tree) * (maxn << 2));
    tot = 0, cnt = 0;
}
void addedge(int u, int v, int w)
{
    ed[tot].to = v;
    ed[tot].next = head[u];
    ed[tot].val = w;
    head[u] = tot++;
}
void dfs(int u)
{
    cnt++;
    bc[u].lef = cnt;
    for(int i = head[u];i ^ -1;i = ed[i].next) dfs(ed[i].to);
    bc[u].rig = cnt;
}
void build(int l, int r, int now)
{
    lj[now].upd = -1;
    if(l == r) return (void)(lj[now].data = -1);
    int mid = (l + r) >> 1;
    build(l, mid, now << 1);
    build(mid + 1, r, now << 1 | 1);
}
void mark_change(int l, int r, int now, int xg)
{
    lj[now].data = xg;
    lj[now].upd = xg;
}
void pushdown(int l, int r, int now)
{
    if(lj[now].upd == -1) return ;
    int mid = (l + r) >> 1;
    mark_change(l, mid, now << 1, lj[now].upd);
    mark_change(mid + 1, r, now << 1 | 1, lj[now].upd);
    lj[now].upd = -1;
}
void update(int l, int r, int now, int ql, int qr, int xg)
{
    if(ql <= l && qr >= r) return mark_change(l, r, now, xg);
    int mid = (l + r) >> 1;
    pushdown(l, r, now);
    if(ql <= mid) update(l, mid, now << 1, ql, qr, xg);
    if(qr > mid) update(mid + 1, r, now << 1 | 1, ql, qr, xg);
}
int ask(int l, int r, int now, int id)
{
    if(l == r) return lj[now].data;
    int mid = (l + r) >> 1;
    if(id <= mid) return ask(l, mid, now << 1, id);
    else return ask(mid + 1, r, now << 1 | 1, id);
}
int main()
{
    int T;
    T = read();
    for(int t = 1; t <= T; t++)
    {
        printf("Case #%d:\n", t);
        init();
        n = read();
        for(int i = 2; i <= n; i++)
        {
            int u, v;
            u = read(), v = read();
            addedge(v, u, 1);
            fa[u]++;
        }
        for(int i = 1; i <= n; i++)
        {
            //从原树根深搜
            if(fa[i] == 0)
            {
                dfs(i);
                break;
            }
        }
        build(1, cnt, 1);
        m = read();
        while(m--)
        {
            char ch[3];
            scanf("%s", ch);
            if(ch[0] == C)
            {
                int x;
                x = read();
                write(ask(1, cnt, 1, bc[x].lef));
                enter;
            }
            else
            {
                int x, y;
                x = read(), y = read();
                update(1, cnt, 1, bc[x].lef, bc[x].rig, y);
            }
        }
    }
    return 0;
}

 

hahaha

标签:print   std   dfs序   get   ||   vector   dde   关系   lazy   

原文地址:https://www.cnblogs.com/thx666/p/9857980.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!