poj2763

时间:2022-02-03 10:18:42
//Accepted    11676 KB    2344 ms
/*
    source:poj2763
    time  :2015.5.29
    by    :songt
  */
/*题解:
树链剖分
基于边权,路径查询
wind第一次在s节点,假如她走到了p节点,那么下次开始的时候他就在p节点
  */
#include <cstdio>
#include <cstring>

;
struct Edge
{
    int u,v;
    Edge(){}
    Edge(int u,int v):u(u),v(v){}
}edge[*imax_n];
int head[imax_n];
*imax_n];
int tot;
void addEdge(int u,int v)
{
    edge[tot]=Edge(u,v);
    next[tot]=head[u];
    head[u]=tot++;
}
int fa[imax_n],deep[imax_n],num[imax_n],son[imax_n];
int p[imax_n],fp[imax_n],top[imax_n];
int pos;
void init()
{
    memset(head,-,sizeof(head));
    memset(next,-,sizeof(next));
    tot=;
    memset(son,-,sizeof(son));
    pos=;
}
int s[imax_n];
int cnt_s;
int vis[imax_n];
void dfs1(int u)
{
    fa[u]=;
    deep[u]=;
    cnt_s=;
    s[cnt_s++]=u;
    memset(vis,,sizeof(vis));
    while (cnt_s)
    {
        ];
        if (vis[x])
        {
            cnt_s--;
            if (x!=u)
            {
                num[fa[x]]+=num[x];
                 || num[fa[x]]<num[x])
                    son[fa[x]]=x;
            }
            continue;
        }
        vis[x]=;
        num[x]=;
        ;i=next[i])
        {
            int v=edge[i].v;
            if (v!=fa[x])
            {
                fa[v]=x;
                deep[v]=deep[x]+;
                s[cnt_s++]=v;
            }
        }
    }
}
void dfs2(int u)
{
    top[u]=u;
    memset(vis,,sizeof(vis));
    cnt_s=;
    s[cnt_s++]=u;
    while (cnt_s)
    {
        ];
        if (vis[x])
        {
            cnt_s--;
            continue ;
        }
        vis[x]=;
        p[x]=pos++;
        fp[p[x]]=x;
        ) continue ;
        ;i=next[i])
        {
            int v=edge[i].v;
            if (v!=fa[x] && v!=son[x])
            {
                top[v]=v;
                s[cnt_s++]=v;
            }
        }
        top[son[x]]=top[x];
        s[cnt_s++]=son[x];
    }
}
struct Tree
{
    int l,r;
    long long sum;
}f[imax_n*];
void build(int t,int l,int r)
{
    f[t].l=l;
    f[t].r=r;
    f[t].sum=;
    if (l==r)
    {
        return ;
    }
    ;
    build(*t,l,mid);
    build(*t+,mid+,r);
}
void update(int t,int k,int value)
{
    if (f[t].l==k && f[t].r==k)
    {
        f[t].sum=value;
        return ;
    }
    ;
    *t,k,value);
    *t+,k,value);
    f[t].sum=f[*t].sum+f[*t+].sum;
}
long long query(int t,int l,int r)
{
    if (f[t].l==l && f[t].r==r)
    {
        return f[t].sum;
    }
    ;
    *t,l,r);
    else
    {
        *t+,l,r);
        *t,l,mid)+query(*t+,mid+,r);
    }
}
void swap(int &a,int &b)
{
    int t=a;
    a=b;
    b=t;
}
long long find(int u,int v)
{
    int f1=top[u],f2=top[v];
    ;
    while (f1!=f2)
    {
        if (deep[f1]<deep[f2])
        {
            swap(f1,f2);
            swap(u,v);
        }
        sum+=query(,p[f1],p[u]);
        u=fa[f1];
        f1=top[u];
    }
    if (u==v) return sum;
    if (deep[u]>deep[v]) swap(u,v);
    sum+=query(,p[son[u]],p[v]);
    return sum;
}
];
int n,m;
int res;

int main()
{
    )
    //scanf("%d%d%d",&n,&m,&res);
    {
        init();
        ;i<n-;i++)
        {
            scanf(],&e[i][],&e[i][]);
            addEdge(e[i][],e[i][]);
            addEdge(e[i][],e[i][]);
        }
        dfs1();
        dfs2();
        build(,,pos-);
        ;i<n-;i++)
        {
            ]]<deep[e[i][]]) swap(e[i][],e[i][]);
            update(,p[e[i][]],e[i][]);
        }
        int kind;
        int u,v;
        ;i<m;i++)
        {
            scanf("%d",&kind);
            )
            {
                scanf("%d",&u);
                printf("%lld\n",find(u,res));
                res=u;
            }
            else
            {
                scanf("%d%d",&u,&v);
                update(,p[e[u-][]],v);
            }
        }
    }
    ;
}

poj2763的更多相关文章

  1. 【lct】poj2763 Housewife Wind

    题意:给你一棵树,边带权,支持两种操作:修改某条边的权值:查询两点之间的最短路. lct主要实现单点修改和路径和. 修改x结点的值只需将x Splay到其所在辅助树的根,然后修改其值,再maintai ...

  2. poj2763(树链剖分 - 边权)

    poj2763 题意 给定一个树形图,某人原来在 s 点,每条边(路)有通过的时间花费,有两种操作:1. 查询某人到 u 点花费的时间 2. 更新某条路的时间花费. 分析 权值在边上,可以把它们 &q ...

  3. POJ2763 Housewife Wind 树链剖分 边权

    POJ2763 Housewife Wind 树链剖分 边权 传送门:http://poj.org/problem?id=2763 题意: n个点的,n-1条边,有边权 修改单边边权 询问 输出 当前 ...

  4. POJ2763 Housewife Wind

      Time Limit: 4000MS   Memory Limit: 65536K Total Submissions: 9701   Accepted: 2661 Description Aft ...

  5. poj2763 树链剖分(线段树)

    注意这里都是把边放到线段树中,所以lca的时候,要注意如果top[x]==top[y] && x==y 的时候已经完成了. 仔细想想边和点的不同之处!!! #include<ma ...

  6. POJ2763 Housewife Wind(DFS序)

    题目:单边修改,树链查询. 这题是边权,不是点权,不过也可以看作是点权. 然后其实就和BZOJ2819一样. #include<cstdio> #include<cstring&gt ...

  7. poj2763(树链剖分)

    题目链接:http://poj.org/problem?id=2763 题意:定一棵带边权的树,要求支持两种操作:1)询问树中某两点间的距离. 2)修改某条边的权值. 分析:树链剖分,边权修改,路径求 ...

  8. 树链剖分——边权poj2763

    边权操作起来也和点权一样,只要把边的权值映射到点上即可,要注意的地方是向上爬的过程中和点权不太一样,还有个特判(WA了几次..) 完整代码 #include<cstring> #inclu ...

  9. poj2763树链剖分边权&plus;区间和

    自己写的比原来的板子常数小了不少嘻嘻,边权处理起来比点权要复杂一下 由于根节点没有被映射的边,其被访问到的顺序是0,直接排除在线段树外 #include<iostream> #includ ...

随机推荐

  1. thinkphp where条件语句整理

    ThinkPHP运算符 与 SQL运算符 对照表 TP运算符 SQL运算符 例子 实际查询条件 eq = $map['id'] = array('eq',100); 等效于:$map['id'] = ...

  2. vs2010常用快捷方式

    1.注释 直接打三个"///"就会出现 /// <summary> ///非方法体上 /// </summary> MusicStoreEntities s ...

  3. Linux 文件

    Linux系统中:.a文件是静态链接库文件.所谓静态链接是指把要调用的函数或者过程链接到可执行文件中,成为可执行文件的一部分.当多个程序都调用相同函数时,内存中就会存在这个函数的多个拷贝,这样就浪费了 ...

  4. Android中监听webview监听是否加载完成

    之前写过一篇捕获Phoengap的webview事件的方法,主要是在实现了CordovaInterface的Activity中,  在onMessage中根据第一个参数的message name来判断 ...

  5. bash下&period; &colon; &lpar;&rpar; &lbrace;&rcub; &lbrack;&rsqb; &lbrack;&lbrack;&rsqb;&rsqb; &lpar;&lpar;&rpar;&rpar;的解释 &lpar;非原创,侵删&rpar;

    Copy from http://blog.chinaunix.net/uid-20380484-id-1692999.html bash下有很多像{}.[]等一些符号命令,下面是我对一些常用的符号命 ...

  6. eclipse环境下日志打印输出

    1.先将jdk配置一下 选Preferences---- 找到自己的jdk所在的位置 2.配置Tomcat window-----preferences------- 找到自己的tomcat所在位置 ...

  7. 教你如何在Drcom下使用路由器上校园网&lpar;以广东工业大学、极路由1S HC5661A为例&rpar;

    免责声明: 在根据本教程进行实际操作时,如因您操作失误导致出现的一切意外,包括但不限于路由器变砖.故障.数据丢失等情况,概不负责: 该技术仅供学习交流,请勿将此技术应用于任何商业行为,所产生的法律责任 ...

  8. 20135327郭皓--Linux内核分析第九周 期中总结

    Linux内核分析第九周 期中总结 一.知识概要 1. 计算机是如何工作的 存储程序计算机工作模型:冯诺依曼体系结构 X86汇编基础 会变一个简单的C程序分析其汇编指令执行过程 2. 操作系统是如何工 ...

  9. mysql之 innobackupex备份&plus;binlog日志的完全恢复【转】

    前言: MySQL的完全恢复,我们可以借助于完整的 备份+binlog 来将数据库恢复到故障点. 备份可以是热备与逻辑备份(mysqldump),只要备份与binlog是完整的,都可以实现完全恢复. ...

  10. Redis 在Golang中使用遇到的坑

    1.从lua脚本传回到go那边的数字是string类型 2.hincrby 返回当前值的计算结果(即存放到redis中的值) 3.hset 一个不存在的key,返回什么呢?即设置失败返回什么错误?(会 ...