题目描述

“我有个愿望,我希望走到你身边。”

这是个奇异的世界,世界上的n-1条路联结起来形成一棵树,每条路有一个对应的权值ci

现在我会给出q组询问或操作。

每次询问我会从一个x点走到y点,初始在x点我会有一个数字v,然后每走过一条权值为c的边,我的v就会变成[v/c],问最后到y时v变成了什么。

每次修改我会修改一条边的权值,保证修改后的权值小于等于原来的权值且不会小于1。

每组询问或操作的格式如下:

询问:1 x y v表示从x走到y,一开始的数字为v。

操作:2 p c表示将第p条边的边权修改为c

输入

第一行两个整数n和q表示点个数和询问与操作个数

接下来n-1行每行三个整数u,v,c表示u与v之间有一条边权为c的边

接下来q行每行第一个数type

如果type=1那么接下来三个数x,y,v表示一组询问

如果type=2那么接下来两个数p,c表示一组操作

输出

对于每组询问输出一个数表示最后的答案

样例输入1


样例输出1


样例输入2


样例输出2


数据范围

对于70%的数据保证1<=n<=1000

对于100%的数据保证1<=n<=100000,1<=ci<=10^18

保证每次修改后的边权小于等于原来的边权且不会小于1

题解:

由于对于百分之百的数据,ci可能会出现10^18。

而对于题目中[v/c]的操作,有几个可以利用的性质:

1)出现一段连续的边c=1时,不需要操作

2)当边数超过62时,答案必定为0

证明2):对∨x∈[1,+∞),x^62>10^18

因此,对于连续的边出现c=1时,用并查集将这些边集的子集合并,方便操作;对于2)还可以判断当边数>62时,直接输出'0'

#include<stdio.h>
#include<string.h>
#define N 100001
using namespace std;
typedef long long ll;
inline int Fs(){
int x=,c=getchar(),f=;
for(;c<||c>;c=getchar())
if(!(c^))
f=-;
for(;c>&&c<;c=getchar())
x=(x<<)+(x<<)+c-;
return x*f;
}
inline ll Fl(){
ll x=,c=getchar(),f=;
for(;c<||c>;c=getchar())
if(!(c^))
f=-;
for(;c>&&c<;c=getchar())
x=(x<<)+(x<<)+c-;
return x*f;
}
struct edge{
ll w;
int v,nxt;
}e[N<<];
ll s[N],s1[N],s2[N];
int n,fst[N],fa[N],dep[N],f[N];
inline void link(int a,int b,ll c){
static int tt;
e[++tt].w=c,
e[tt].v=b,
e[tt].nxt=fst[a],
fst[a]=tt;
}
void dfs(int x){
for(int j=fst[x];j;j=e[j].nxt)
if(!fa[e[j].v])
fa[e[j].v]=x,
s[e[j].v]=e[j].w,
dep[e[j].v]=dep[x]+,
dfs(e[j].v);
}
int bin(int x){
int p1,p2=x;
for(;x^f[x];x=f[x])
;
for(;p2^f[p2];)
p1=f[p2],
f[p2]=x,
p2=p1;
return x;
}
int main(){
freopen("walk.in","r",stdin),
freopen("walk.out","w",stdout),
n=Fs();
int q=Fs();
for(int i=;i<n;i++){
int x=Fs(),y=Fs();
ll z=Fl();
link(x,y,z),
link(y,x,z);
}
dfs(fa[]=);
for(int i=;i<=n;i++)
f[i]=i;
for(int i=;i<=n;i++)
if(!(s[i]^)){
int y=bin(i);
int x=bin(fa[i]);
f[y]=x;
}
for(;q;q--){
ll v;
int x=Fs(),y,d;
if(x&){
x=Fs();
y=Fs();
x=bin(x);
y=bin(y);
v=Fl();
int l1=,l2=;
for(;x^y&&l1+l2<;)
dep[x]>dep[y]?
(s1[++l1]=s[x],
x=bin(fa[x])):
(s2[++l2]=s[y],
y=bin(fa[y]));
if(l1+l2>=)
puts("");
else{
for(int i=;i<=l1;i++)
v/=s1[i];
for(int i=l2;i>=;i--)
v/=s2[i];
printf("%I64d\n",v);
}
}
else{
d=Fs()<<;
v=Fl();
y=e[d].v;
x=fa[y];
fa[e[d-].v]^y
?:(d--,
y=e[d].v,
x=fa[y]);
s[y]=v;
if(!(s[y]^))
x=bin(x),
y=bin(y),
f[y]=x;
}
}
fclose(stdin),
fclose(stdout);
return ;
}

NOIP模拟赛 行走的更多相关文章

  1. NOIP模拟赛20161022

    NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...

  2. NOIP模拟赛 6.29

    2017-6-29 NOIP模拟赛 Problem 1 机器人(robot.cpp/c/pas) [题目描述] 早苗入手了最新的Gundam模型.最新款自然有着与以往不同的功能,那就是它能够自动行走, ...

  3. contesthunter暑假NOIP模拟赛第一场题解

    contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...

  4. NOIP模拟赛 by hzwer

    2015年10月04日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...

  5. 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程

    数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...

  6. 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...

  7. 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...

  8. 队爷的新书 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的新书 题解:看到这题就想到了 poetize 的封 ...

  9. CH Round #58 - OrzCC杯noip模拟赛day2

    A:颜色问题 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2358%20-%20OrzCC杯noip模拟赛day2/颜色问题 题解:算一下每个仆人到它的目的地 ...

随机推荐

  1. CSS 伪类

    Link The :link CSS pseudo-class lets you select links inside elements. This will select any link whi ...

  2. iOS自动化编译

    最近研究了一下iOS的自动化编译,目的是为了简化测试和开发的同学沟通协调的次数,实现测试同学可以随时从网页操作编译SVN最新源码并打包ipa进行测试. 具体思路是通过从配置文件读取需要编译的项目配置列 ...

  3. 在Json解析过程中,我为什么用object1.optInt ,和 object1.optString

    今天在做Json解析的时候,出现了一段代码没执行的问题,于是找了一下原因: 1.原代码是:   发现 红色的一句 没有执行,查看控制台发现了异常 2.修复bug ,正确的代码为        3.总结 ...

  4. Binder中的asInterface解析

    在使用AIDL通信的时候,在Stub类中都会生成一个asInterface函数,以<Android开发艺术探索>中的例子来分析,其生成的asInterface函数源码为: /** * Ca ...

  5. tomcat常见错误及解决方案

    一,tomcat启动时错误 1:The JAVA_HOME environment variable is not defined This environment variable is neede ...

  6. mysql 数据库乱码问题

    mysql 数据库乱码问题,按如下顺序检查,一步一步排除出错位置. 最好全部编码都使用UTF8编码. 网页页面编码方式使用UTF8: <meta http-equiv="Content ...

  7. 500 OOPS: vsftpd: refusing to run with writable root inside chroot()

    Ubuntu 12.04 64bit系统下安装的vsftpd,在登陆时提示500 OOPS: vsftpd: refusing to run with writable root inside chr ...

  8. Android海康监控视频调用demo

    一. 开发环境 1. 操作系统:windows7(X64) 2. 开发工具:eclipse adt Build: v22.2.1-833290 JDK7 android SDK 3. 客户端设备版本: ...

  9. Kafka 分布式的,基于发布/订阅的消息系统

    Kafka是一种分布式的,基于发布/订阅的消息系统.主要设计目标如下: 通过O(1)的磁盘数据结构提供消息的持久化,这种结构对于即使数以TB的消息存储也能够保持长时间的稳定性能. 高吞吐量:即使是非常 ...

  10. SQL查询数据库中所有指定类型的字段名称和所在的表名

    --查询数据库中所有指定类型的字段名称和所在的表名 --eg: 下面查的是当前数据库中 所有字段类型为 nvarchar(max) 的字段名和表名 SELECT cols.object_id , co ...