题目描述

数据范围

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

对于100%的数据保证 n,q <= 10^5,c_i,v_i <= 10^{18}

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

解法

由于c最大只有264,所以整除大于1的权值最多除64次,所以使用利用并查集将权值为1的边合并,然后每次询问只需寻找64条权值大于1的边即可。


树链剖分也是可以的。

代码

#include<iostream>
#include<stdio.h>
#include<string.h>
#include<math.h>
#include<algorithm>
#define ll long long
#define ln(x,y) ((ll)(log(x)/log(y)))
using namespace std;
const char* fin="walk.in";
const char* fout="walk.out";
const ll inf=0x7fffffff;
const ll maxn=100007,maxm=maxn*2,maxk=20;
ll n,m,i,j,k,l,o,tot;
ll fi[maxn],la[maxm],ne[maxm],va[maxm],limit;
ll fa[maxn][maxk],w[maxn],dad[maxn],de[maxn];
ll a[maxn],b[maxn];
ll getdad(ll v){
if (dad[v]==0) return v;
dad[v]=getdad(dad[v]);
return dad[v];
}
void add_line(ll a,ll b,ll c){
tot++;
ne[tot]=fi[a];
la[tot]=b;
va[tot]=c;
fi[a]=tot;
}
void dfs(ll v,ll from){
ll i,j,k;
de[v]=de[from]+1;
for (i=1,j=ln(de[v],2);i<=j;i++){
k=fa[v][i-1];
fa[v][i]=fa[k][i-1];
}
for (k=fi[v];k;k=ne[k])
if (la[k]!=from){
if (va[k]==1) dad[la[k]]=getdad(v);
w[la[k]]=va[k];
fa[la[k]][0]=v;
dfs(la[k],v);
}
}
ll lca(ll u,ll v){
ll i,j,k;
if (de[u]<de[v]) swap(u,v);
for (i=ln(de[u]-de[v],2);i>=0;i--) if (de[fa[u][i]]>de[v]) u=fa[u][i];
if (de[u]!=de[v]) u=fa[u][0];
for (i=ln(de[u],2);i>=0;i--) if (fa[u][i]!=fa[v][i]) u=fa[u][i],v=fa[v][i];
if (u!=v) return fa[u][0];
return u;
}
int main(){
freopen(fin,"r",stdin);
freopen(fout,"w",stdout);
scanf("%lld%lld",&n,&m);
for (i=1;i<n;i++){
scanf("%lld%lld%lld",&j,&k,&l);
add_line(j,k,l);
add_line(k,j,l);
}
dfs(1,0);
for (i=1;i<=m;i++){
scanf("%lld",&j);
if (j==1){
scanf("%lld%lld%lld",&j,&k,&l);
ll LCA=lca(j,k);
limit=ln(l,2)+3;
a[0]=b[0]=0;
while (a[0]+b[0]<=limit && de[j]>de[LCA]){
if (w[j]==1) j=getdad(j);
else{
a[++a[0]]=w[j];
j=fa[j][0];
}
}
while (a[0]+b[0]<=limit && de[k]>de[LCA]){
if (w[k]==1) k=getdad(k);
else{
b[++b[0]]=w[k];
k=fa[k][0];
}
}
if (a[0]+b[0]>limit) printf("0\n");
else{
for (j=1;j<=a[0];j++) l/=a[j];
for (k=b[0];k;k--) l/=b[k];
printf("%lld\n",l);
}
}else{
scanf("%lld%lld",&j,&k);
l=la[j*2];
o=la[j*2-1];
if (l==fa[o][0]){
if (w[o]!=1 && k==1) dad[o]=l;
w[o]=k;
}else{
if (w[l]!=1 && k==1) dad[l]=o;
w[l]=k;
}
}
}
return 0;
}

启发

a/b/c变成a/(b∗c)是可以的,所以可以使用树链剖分。


发掘题目性质,例如一个数连续整除以若干个大于1的数,不超过log次后,这个数会变为0。

【JZOJ4846】【NOIP2016提高A组集训第5场11.2】行走的更多相关文章

  1. JZOJ 【NOIP2016提高A组集训第16场11.15】兔子

    JZOJ [NOIP2016提高A组集训第16场11.15]兔子 题目 Description 在一片草原上有N个兔子窝,每个窝里住着一只兔子,有M条路径连接这些窝.更特殊地是,至多只有一个兔子窝有3 ...

  2. JZOJ 【NOIP2016提高A组集训第16场11.15】SJR的直线

    JZOJ [NOIP2016提高A组集训第16场11.15]SJR的直线 题目 Description Input Output Sample Input 6 0 1 0 -5 3 0 -5 -2 2 ...

  3. 【NOIP2016提高A组集训第4场11.1】平衡的子集

    题目 夏令营有N个人,每个人的力气为M(i).请大家从这N个人中选出若干人,如果这些人可以分成两组且两组力气之和完全相等,则称为一个合法的选法,问有多少种合法的选法? 分析 如果暴力枚举每个人被分到哪 ...

  4. 【JZOJ4841】【NOIP2016提高A组集训第4场11.1】平衡的子集

    题目描述 夏令营有N个人,每个人的力气为M(i).请大家从这N个人中选出若干人,如果这些人可以分成两组且两组力气之和完全相等,则称为一个合法的选法,问有多少种合法的选法? 数据范围 40%的数据满足: ...

  5. 【NOIP2016提高A组集训第14场11.12】随机游走

    题目 YJC最近在学习图的有关知识.今天,他遇到了这么一个概念:随机游走.随机游走指每次从相邻的点中随机选一个走过去,重复这样的过程若干次.YJC很聪明,他很快就学会了怎么跑随机游走.为了检验自己是不 ...

  6. 【NOIP2016提高A组集训第13场11.11】最大匹配

    题目 mhy12345学习了二分图匹配,二分图是一种特殊的图,其中的点可以分到两个集合中,使得相同的集合中的点两两没有连边. 图的"匹配"是指这个图的一个边集,里面的边两两不存在公 ...

  7. 【NOIP2016提高A组集训第14场11.12】随机游走——期望+树形DP

    好久没有写过题解了--现在感觉以前的题解弱爆了,还有这么多访问量-- 没有考虑别人的感受,没有放描述.代码,题解也写得歪歪扭扭. 并且我要强烈谴责某些写题解的代码不打注释的人,像天书那样,不是写给普通 ...

  8. 【JZOJ4901】【NOIP2016提高A组集训第18场11.17】矩阵

    题目描述 他是一名普通的农电工,他以一颗无私奉献的爱岗敬业之心,刻苦钻研业务,以娴熟的技术.热情周到的服务赢得了广大客户的尊敬和赞美.他就是老百姓称为"李电"的李春来. 众所周知, ...

  9. 【JZOJ4898】【NOIP2016提高A组集训第17场11.16】人生的价值

    题目描述 NiroBC终于找到了人生的意义,可是她已经老了,在新世界,没有人认识她,她孤独地在病榻上回顾着自己平凡的一生,老泪纵横.NiroBC多么渴望再多活一会儿啊! 突然一个戴着黑色方框眼镜,方脸 ...

随机推荐

  1. 在windows系统和linux系统中查询IP地址命令的不同

    在linux和windows系统上查询IP地址的命令是不一样的.         在linux中的命令行模式下,输入ifconfig即可查询到IP.而在windows系统下要查询IP地址需要先打开do ...

  2. C++11的for循环的新用法

    字符串 string str = "this is a string"; for(auto ch : str) cout << ch << endl; 等价 ...

  3. Redis源码解析:21sentinel(二)定期发送消息、检测主观下线

    六:定时发送消息 哨兵每隔一段时间,会向其所监控的所有实例发送一些命令,用于获取这些实例的状态.这些命令包括:"PING"."INFO"和"PUBLI ...

  4. TCP/TP:DNS区域(Zone)

    之前阅读资料不是特别明白,看到一个博主的解释,豁然开朗,特此记录. https://blog.csdn.net/huangzx3/article/details/79347556 DNS区域(ZONE ...

  5. 移动端页面-点击input输入框禁止放大效果

    点击input输入框会获取焦点并且放大 解决方法:在项目根目录找到 index.html <meta name="viewport" content="width= ...

  6. call(this)自记

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. php解决高并发(文件锁)

    文件锁分为两种方式: [一].阻塞模式:(如果其他进程已经加锁文件,当前进程会一直等其他进程解锁文件后继续执行) <?php //连接数据库 $con=mysqli_connect(" ...

  8. 锋利的jQuery学习笔记之jQuery选择器

    在介绍jQuery选择器之前,先简单介绍一下CSS选择器---> 一.CSS选择器 常见的CSS选择器有以下几种: 选择器 语法 描述 示例 标签选择器 E{CSS规则} 以文档元素为选择符 t ...

  9. mysql向某个字段前边追加一个字符串CONCAT命令

    比如,我在处理图片的时候把https写成了tps 那我就要补全 UPDATE t_article set imgs=CONCAT('ht',imgs);

  10. IO流3 --- File类的常用方法2 --- 技术搬运工(尚硅谷)

    File类的判断功能 @Test public void test5(){ File file = new File("hello.txt"); //判断是否是文件目录 Syste ...