这一场其实有重大的意义,因为是除夕跨年,不过我FST掉大分了(ks)

  • 题意:给你一个n点,m条边的带权图,q次询问,每次给你\(x\),每个边权为\(abs(E[i].w-x)\)答案为所有询问最小生成树边权和。然后输出所有询问结果的异或和。
  • 思路:

    因为\(n(n<=50),m(m<=300)\)很小。而\(k(k<=10^7)\)又很大。所以肯定不能每个询问直接求,这里是把询问的x,分块预处理。

    如果有两条边\(w1,w2(w1<w2)\)选1条,原来最小生成树,选边一定选w1,但仔细考虑绝对值情况下,也就只有两种情况:令\(mid=\frac{w1+w2}{2}\)。 当\(x<mid\),就选\(w1\),当\(x=mid\)都可以,当\(x>mid\)选\(w2\),所以\(mid\)的感觉就像一个分解线

    因此我们排序且离散化出任意两条边的\(mid\)。对于每个\(mid\)求其最小生成树,存入sum[mid]。当\(x\)属于\([mid[i],mid[i+1])\)之间就可以用这个值。[因为mid实际求的时候用的上取整]

    不过我们只求了\(x=mid\)时的mnsum,范围内其它的怎么求呢?

    发现如果我们再在\(mid[]\)集合中加入每个边权。发现每个块内每条选的边的权值都是会随着x++,对mnsum=+1/-1的。

    证明:如果上面条件不满足,那么一定存在一个边权在(mid[i],mid[i+1])

    然而\(mid[]\)包含所有边权,矛盾。

    所以处理出dta[mid]表示x++,mnsum的变化。

    最后询问的时候二分一下在哪个块。

    ps.注意一下边权排序的时候abs相等时,优先选对dta贡献大的(即边权)大的。
  • code
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=55;
const int M=305;
struct edge {int qs,x,y;ll z;}E[M],A[M];
bool cmp(edge u,edge v) {return u.z==v.z?u.qs<v.qs:u.z<v.z;}
ll sum[M*M],val[M*M];
int cv,tot,fa[N],dta[M*M];
int g_fa(int u) {return fa[u]==u?u:fa[u]=g_fa(fa[u]);}
int main() {
int n,m;
scanf("%d%d",&n,&m);
val[++tot]=0;val[++tot]=1e8+1;
for(int i=1;i<=m;i++) {scanf("%d%d%lld",&A[i].x,&A[i].y,&A[i].z);val[++tot]=A[i].z;}
for(int i=1;i<=m;i++) for(int j=i+1;j<=m;j++)val[++tot]=(A[i].z+A[j].z+1)>>1;
sort(val+1,val+1+tot);
cv=unique(val+1,val+1+tot)-val-1;
for(int j=1;j<=cv;j++) {
for(int i=1;i<=n;i++)fa[i]=i;
for(int i=1;i<=m;i++) E[i]=(edge){(A[i].z>val[j])?-1:1,A[i].x,A[i].y,abs(A[i].z-val[j])};
sort(E+1,E+1+m,cmp);
for(int i=1,t=1;i<=m&&t<n;i++) {
int u=g_fa(E[i].x),v=g_fa(E[i].y);
if(u==v)continue;
fa[u]=v;
sum[j]+=E[i].z;dta[j]+=E[i].qs;t++;
}
}
ll xos=0,x;
int p,k,a,b,c;scanf("%d%d%d%d%d",&p,&k,&a,&b,&c);
for(int i=1;i<=k;i++) {
if(i<=p) scanf("%lld",&x);
else x=(x*a+b)%c;
int y=upper_bound(val+1,val+1+cv,x)-val-1;
ll res=sum[y]+1ll*dta[y]*(x-val[y]);
xos^=res;
}
printf("%lld",xos);
return 0;
}

Educatinal CF #122(Div. 2) E . Spanning Tree Queries的更多相关文章

  1. CF #371 (Div. 2) C、map标记

    1.CF #371 (Div. 2)   C. Sonya and Queries  map应用,也可用trie 2.总结:一开始直接用数组遍历,果断T了一发 题意:t个数,奇变1,偶变0,然后与问的 ...

  2. CF# Educational Codeforces Round 3 E. Minimum spanning tree for each edge

    E. Minimum spanning tree for each edge time limit per test 2 seconds memory limit per test 256 megab ...

  3. Problem 1566 - C - Spanning Tree 动态最小生成树

    Problem 1566 - C - Spanning Tree 给出一个联通图,然后每次加一条边,每次需要求最小生成树 1 #include <iostream> 2 #include ...

  4. CF #376 (Div. 2) C. dfs

    1.CF #376 (Div. 2)    C. Socks       dfs 2.题意:给袜子上色,使n天左右脚袜子都同样颜色. 3.总结:一开始用链表存图,一直TLE test 6 (1)如果需 ...

  5. CF #375 (Div. 2) D. bfs

    1.CF #375 (Div. 2)  D. Lakes in Berland 2.总结:麻烦的bfs,但其实很水.. 3.题意:n*m的陆地与水泽,水泽在边界表示连通海洋.最后要剩k个湖,总要填掉多 ...

  6. CF #374 (Div. 2) D. 贪心,优先队列或set

    1.CF #374 (Div. 2)   D. Maxim and Array 2.总结:按绝对值最小贪心下去即可 3.题意:对n个数进行+x或-x的k次操作,要使操作之后的n个数乘积最小. (1)优 ...

  7. 【HDU 4408】Minimum Spanning Tree(最小生成树计数)

    Problem Description XXX is very interested in algorithm. After learning the Prim algorithm and Krusk ...

  8. 数据结构与算法分析–Minimum Spanning Tree(最小生成树)

    给定一个无向图,如果他的某个子图中,任意两个顶点都能互相连通并且是一棵树,那么这棵树就叫做生成树(spanning tree). 如果边上有权值,那么使得边权和最小的生成树叫做最小生成树(MST,Mi ...

  9. Educational Codeforces Round 3 E. Minimum spanning tree for each edge LCA/(树链剖分+数据结构) + MST

    E. Minimum spanning tree for each edge   Connected undirected weighted graph without self-loops and ...

随机推荐

  1. 前端每日实战:116# 视频演示如何用 CSS 和原生 JS 开发一个监控网络连接状态的页面

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/oPjWvw 可交互视频 此视频是可 ...

  2. Android 预置APK

    1.   预置apk,使其不可卸载   第一步:      在 "/vendor/huawei/packages/apps" 目录下创建一个对应名称的文件夹.   第二步:   将 ...

  3. Android 接入腾讯IM即时通信(详细图文)

    原文地址:Android 接入腾讯IM即时通信(详细图文) | Stars-One的杂货小窝 腾讯云IM官网文档上提供了带UI模块和不带UI模块的,本文是基于带UI模块进行了Module封装,可以方便 ...

  4. Spring配置文件-Bean生命周期配置(init-method方法,destory-method方法)

    1.UserDaoImpl类 public class UserDaoImpl implements UserDao { public UserDaoImpl(){ System.out.printl ...

  5. 2021.08.10 Euler函数总结

    2021.08.10 Euler函数总结 知识: 记 φ(n) 表示在 [1,n] 中与 n互质的数的个数. 1.p为质数,则 \[φ(p^l)=p^l-p=p^{l-1}(p-1) \] 注:每p个 ...

  6. MySQL Router重装后重新连接集群进行引导出现的——此主机中之前已配置过的问题

    问题出现的前因: 因为重新安装了MySQL Router,然后打算重新连接上目标集群进行MySQL Router的初始化引导,结果报错了! [root@linux666 system]# mysqlr ...

  7. 【SpringBoot实战】视图技术-Thymeleaf

    前言 在一个Web应用中,通常会采用MVC设计模式实现对应的模型.视图和控制器,其中,视图是用户看到并与之交互的界面.对最初的Web应用来说,视图是由HTML元素组成的静态界面:而后期的Web应用更倾 ...

  8. web服务报错类型

    401:无权限(HttpStatus.UNAUTHORIZED) 404:页面找不到 405:不支持get/post请求,如只支持get请求但传了post请求 400:请求格式错误,如不为null但传 ...

  9. XCTF练习题---MISC---stage1

    XCTF练习题---MISC---stage1 flag:AlphaLab 解题步骤: 1.观察题目,下载附件 2.打开附件后发现是一张图片,初步判断是图片隐写,上Stegsolve进行转换,得到一张 ...

  10. .NET混合开发解决方案5 WebView2运行时与分发应用

    系列目录     [已更新最新开发文章,点击查看详细] 发布使用Microsoft Edge WebView2的应用程序时,客户端计算机上需要安装WebView2运行时,可以安装自动更新的Evergr ...