#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <cmath>
#define ll long long
#define INF 2147483647
#define ll_INF 9223372036854775807
using namespace std;
inline int read(){
int x = 0,tmp = 1;char ch = getchar();
while( ch < '0' || ch > '9' ) {if ( ch == '-' ) tmp = -1; ch = getchar();}
while( ch >= '0' && ch <= '9'){x = x * 10 + ch - '0'; ch = getchar(); }
return x * tmp;
}
struct Point {
int to, next;
} edge[21000];
int head[21000], idx = 0, w[21000], dep[21000], f[21000][16], sum[21000];
int maxdep, C[21000];
inline void ade( int u, int v ) {
edge[++ idx].to = v;
edge[idx].next = head[u];
head[u] = idx;
}
void dfs( int x ) {
for( int i = 1 ; i <= 15 ; ++ i ) {
if( dep[x] < ( 1 << i ) ) break;
f[x][i] = f[f[x][i - 1]][i - 1];
}
for( int i = head[x] ; i != -1 ; i = edge[i].next ) {
int now = edge[i].to;
dep[now] = dep[x] + 1;
f[now][0] = x;
if( dep[now] % 2 == 0 ) w[now] = -w[now];
sum[now] = w[now] + sum[x];
dfs( now );
}
}
inline int lca( int u, int v ) {
if( dep[u] > dep[v] ) swap( u, v );
for( int i = 15 ; i >= 0 ; -- i ) if( dep[f[v][i]] >= dep[u] ) v = f[v][i];
if( u == v ) return u;
for( int i = 15 ; i >= 0 ; -- i ) if( f[v][i] != f[u][i] ) v = f[v][i], u = f[u][i];
return f[u][0];
}
inline int query( int k ) {
if( k < 1 ) return 0;
int ret = 0;
for( int i = k ; i ; i -= i&-i ) ret += C[i];
return ret;
}
int main(){
memset( dep, 0, sizeof( dep ) );
memset( head, -1, sizeof( head ) );
int N = read(), Q = read();
for( int i = 1 ; i <= N ; ++ i ) w[i] = read();
int boss;
for( int i = 1 ; i <= N ; ++ i ) {
int u = read();
if( u == -1 ) {
boss = i;
continue;
}
ade( u, i );
}
dep[boss] = 1; sum[boss] = w[boss]; f[boss][0] = 0;
dfs( boss );
maxdep = 0;
for( int i = 1 ; i <= N ; ++ i ) maxdep = max( maxdep, dep[i] );
for( int i = 1 ; i <= Q ; ++ i ) {
char ch = getchar();
while( ch != 'M' && ch != 'A' ) ch = getchar();
if( ch == 'M' ) {
int lv = read(), t = read();
if( lv % 2 == 0 ) t = -t;
for( int i = lv ; i <= maxdep ; i += i&-i ) C[i] += t;
} else {
int x = read(), y = read();
int k = lca( x, y );
int ans = sum[x] + sum[y] + w[k] - 2 * sum[k] + query( dep[x] ) + query( dep[y] ) - query( dep[k] ) - query( dep[k] - 1 );
printf( "%d\n", abs( ans ) );
}
} return 0;
} /**************************************************************
Problem: 1028
User: ARZhu
Language: C++
Result: 正确
Time:0 ms
Memory:3428 kb
****************************************************************/

vijos1710 Mrw的工资计划的更多相关文章

  1. JDOJ 2225 工资计划

    JDOJ 2225: 工资计划 https://neooj.com/oldoj/problem.php?id=2225 Description 高考结束后,同学们大都找到了一份临时工作,渴望挣得一些零 ...

  2. 评点SAP HR功能及人力资源管理软件

    评点SAP HR功能及人力资源管理软件   本文导航 第1页:my SAP 人力资源软件 第2页:my SAP HR协同功能 第3页:组织结构管理 第4页:mySAPTM HR的战略功能 第5页:集成 ...

  3. 实战java虚拟机的学习计划图(看懂java虚拟机)

    啥也不说了,实战java虚拟机,好好学习,天天向上!针对自己的软肋制定学习计划. 一部分内容看完,自己做的学习笔记和感想. 学java很简单,但懂java会有难度,如果你的工资还没超过1W,那是时候深 ...

  4. 如何用分析函数找出EMP表中每个部门工资最高的员工

    EMP表是Oracle测试账户SCOTT中的一张雇员表,首先,我们来看看emp表的数据 SQL> select * from emp; EMPNO ENAME JOB MGR HIREDATE ...

  5. 2014总结&2015计划

    2014总结&2015计划 今天是2015/1/1,新的一年终于到来了,昨天老板要求提交2014的工作总结和2015的工作计划,正好提醒我,要总结和计划了. 先回顾2014年初的计划: 新年计 ...

  6. HDU--杭电--4502--吉哥系列故事——临时工计划--背包--01背包

    吉哥系列故事——临时工计划 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others) To ...

  7. 工资不高也要给自己放假 这几款APP估计你用得上

    我是这样的一个人,我宁愿工资不高,只要给我足够的假期,那我就满足了.都说上班就是为了赚钱,但如果身体不好,赚再多的钱也是无福享受,所以建议各位,有机会的话,一定要抽出时间去旅游,去放松. 现在我们外出 ...

  8. HTML5-前端开发很火且工资很高?

    前言 晚上逛论坛看到一篇对从事HTML5前端开发的文章写的非常不错,和目前的市场形势差不多,然后我在其基础上给大家进行加工总结一下分享给大家.今天我们谈论的话题是<<为什么从事HTML5前 ...

  9. Filecoin官方更新: Q4工作进展和2018年工作计划

    ICO过后,Filecoin团队一直没有对外更新过工作计划(很多投资人都等待的不耐烦了).经过漫长的等待,在新年的第一个工作日,我们终于等来了来自于filecoin团队的声音, 这次更新真是出乎小编的 ...

随机推荐

  1. cmake README.TXT

    { cmake .//在当前路径下构建项目 cmake --build .//在当前路径下生成项目(默认为debug)//cmake --build . --config release//在当前路径 ...

  2. Repeatable Read

    在Repeatable Read隔离级别下,一个事务可能会遇到幻读(Phantom Read)的问题. 幻读是指,在一个事务中,第一次查询某条记录,发现没有,但是,当试图更新这条不存在的记录时,竟然能 ...

  3. Django项目:CRM(客户关系管理系统)--84--74PerfectCRM实现CRM权限和权限组限制访问URL

    #models.py # ————————01PerfectCRM基本配置ADMIN———————— from django.db import models # Create your models ...

  4. NOIp2018集训test-10-20 (bike day6)

    B 君的第一题 lanzhou $x^{\frac{p-1}{2}}\equiv 1(mod\ p)$ $x\equiv x*x^{\frac{p-1}{2}} (mod\ p)$ $x\equiv ...

  5. 兼容ie8的多维数组——深拷贝

    浅拷贝只是把对象的内存位置指针给拷贝了,若修改拷贝对象,则原对象也会跟踪修改. var a = {a : 'old', b : { c : 'old'}} var b = Object.assign( ...

  6. base64、sha256、MD5加密

    异或可逆加密操作:A对B异或结果C:A对C异或结果为A:二次异或是本身package en_decode; public class test { public static String xor(S ...

  7. form提交跳转问题

    $.ajax({ type: "POST", url: url, data: $('.form-horizontal').serialize(), 提交form表单 success ...

  8. docker container 的操作

    删除所有退出的容器 docker container rm $(docker ps -aq)

  9. Hadoop 基础知识

    Hadoop 数据是存储在HDFS, Mapreduce 是一种计算框架,负责计算处理. HDFS上的数据存储默认是本地节点数据一份,同一机架不同节点一份,不同机架不同节点一份.默认是存储3份 HDF ...

  10. 国内pypi镜像

    V2EX pypi.v2ex.com/simple 豆瓣 http://pypi.douban.com/simple 阿里云(推荐使用) http://mirrors.aliyun.com/pypi/ ...