Sirni题解(最小生成树,埃氏筛)(继 Liang-梁)
目录
前言
本篇是对Liang-梁的Sirni(最小生成树,埃氏筛)的后继博客。
通篇原文:https://blog.csdn.net/qq_37555704/article/details/97107653?tdsourcetag=s_pcqq_aiomsg
本文稍加修正,分析了一些错误。
题意
给你 n 个点,每个点有一权值 Pi,两点i,j的边权为min(Pi%Pj,Pj%Pi),求最小生成树。
数据范围:n<=1e5,Pi<=1e7
思路
以下是原文:
首先30分我们可以通过枚举两两连边后用 Kruskal 做,复杂度 O(n2logn2)
其实我们排序时还可以用类似桶排序的方法
用vector或者前向星存储边访问,但是还是会超时,却给我们正解提供思路,然后考虑正解,
我们记值域为 T=[1,1e7]
我们假设两个点 a,b 可以发现若 Pa≤Pb 那么取 min 时只可能取Pb%Pa
那我们如何决策呢首先我们可以将所有Pb=kPa 的点缩成一个点,保存最小的 Pa ,因为他们相连的代价为0,我们可以用类似埃氏筛的方法处理
然后场上所有 Pa,Pb 都是不同的且不存在倍数关系我们发现,算法瓶颈在于边太多了,于是考虑减少边的数量(即可以判断一些不会选的边提前去除), 怎么做呢
假设有三个点 a,b,c 满足 Pa < Pb < Pc并且 Pb=k∗Pa+s,Pc=k∗Pa+t(0< s <Pa) 那 a,b 连边代价为 s ; a,c连边代价为 t ;b,c 连边代价 q 虽然不知道是多少但有一个范围即 :0≤q≤t−s
给这三个点连边只有三种情况:1.a−b−c
代价w1:s+q , s≤w1≤t
2.b−a−c
代价w2: s+t,w2=s+t
3.a−c−b
代价 w3:t+q,t≤w3≤2∗t−s于是w<min(w2,w3)w1<min(w2,w3),k一定时,对于a,ab连边是最优的, b-c这条边我们会在对于b考虑时决策我们记 f(i,k) 表示
那我们发现就只把 k 枚举一遍找到最小一个满足Px=k∗Pa+s(0<s<Pa)的Px,i,x 连边即可
那么问题转化为 将P 数组在值域为[1,1e7]中bool标记,后对于一个值 x 快速找到在它右侧第一个出现的值,那么从右至左简单的Dp扫一遍即可
后面用 30分的第2种做法即可分析一下,由于 Pi 互不相同,那么枚举Pi的倍数时我们的边上限为 Tloglogn类似埃氏筛的时间复杂度,于是桶排序访问时间复杂度为 O(n+T)
那么总的时间复杂度为 O(Tloglogn)
相信大家仔细想想就会发现,若是强制缩点,一些数据是过不了的。
若是有Pj是Pi倍数的话,相当于 i 和 j 有一条权值为零的边,这样的边无论多连几条都没有关系,所以不如就把所有这样的边都先连上,然后再判断权值非零的边。
强制缩点指在上述边都连上情况下,把所有连通的点(无向,所以只要有边就连通)都 蹂 揉成一个点,也就是说,被缩进去的点的权值都不存在了,原作者认为这不影响边的判断。
但是,随便来一组数据就过不了,比如
4
6 18 9 7
若是缩点,最后就缩成了6,9,7,算出来是 3。实际上依次连 9——18——6——7最小,答案是1。
一些建议
要打这道题的人,给些建议:
- 卡常之类的不要过火,走错方向了。
- 用Kruskal做时,不要用优先队列,不要用vector,用数组+sort就行。
- 算DP时,最右边最大的DP值为inf。
Sirni题解(最小生成树,埃氏筛)(继 Liang-梁)的更多相关文章
- 埃氏筛优化(速度堪比欧拉筛) + 洛谷 P3383 线性筛素数 题解
我们一般写的埃氏筛消耗的时间都是欧拉筛的三倍,但是欧拉筛并不好想(对于我这种蒟蒻) 虽然 -- 我 -- 也可以背过模板,但是写个不会的欧拉筛不如写个简单易懂的埃氏筛 于是就有了优化 这个优化还是比较 ...
- 「CF779B」「LOJ#10201.」「一本通 6.2 练习 4」Sherlock and His Girlfriend(埃氏筛
题目描述 原题来自:Codeforces Round #400 B. Sherlock 有了一个新女友(这太不像他了!).情人节到了,他想送给女友一些珠宝当做礼物. 他买了 nnn 件珠宝.第 iii ...
- U138097 小鱼吃大鱼 埃氏筛
题目描述 小P同学在养殖一种非常凶狠的鱼,而且与其他鱼类不同,这种鱼越大越温顺,反而小鱼最凶残.当两条鱼相遇时, 小鱼会不断撕咬大鱼,每一口都咬下与它自身等重的肉(小鱼保持体重不变),直到大鱼的体重小 ...
- CodeForces - 385C Bear and Prime Numbers (埃氏筛的美妙用法)
Recently, the bear started studying data structures and faced the following problem. You are given a ...
- cf1154G 埃氏筛应用
直接用埃氏筛也可以做,但是这题写起来有点恶臭.. 更加简单的写法是直接枚举gcd=k,然后里面再枚举一次i*k,即找到k两个最小的倍数,看起来复杂度很高,但其实也是埃氏筛的复杂度 因为每次枚举gcd, ...
- [JXOI 2018] 游戏 解题报告 (组合数+埃氏筛)
interlinkage: https://www.luogu.org/problemnew/show/P4562 description: solution: 注意到$l=1$的时候,$t(p)$就 ...
- 埃氏筛+线段树——cf731F
从2e5-1依次枚举每个数作为主显卡,然后分段求比它大的数的个数,这里的复杂度是调和级数ln2e5,即埃氏筛的复杂度.. #include<bits/stdc++.h> using nam ...
- 数论(8):min_25 筛(扩展埃氏筛)
min_25 筛介绍 我们考虑这样一个问题. \[ans=\sum_{i = 1}^nf(i)\\ \] 其中 \(1 \le n \le 10^{10}\) 其中 \(f(i)\) 是一个奇怪的函数 ...
- hdu.5212.Code(莫比乌斯反演 && 埃氏筛)
Code Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Total Submi ...
随机推荐
- 设置C#启动进程但不显示命令行窗口
设置一下Process类型相关的配置属性即可,直接上代码. //记得引入命名空间 //using System.Diagnostics; //获得当前环境的基路径 string basePath = ...
- C#中常用的目录|文件|路径信息操作
更新记录 本文迁移自Panda666原博客,原发布时间:2021年5月16日. 说明 .NET的类库API设计的非常优秀,再加上文档docs.com写的非常优秀,写代码给人一种十分优雅的感觉. 获得当 ...
- mybatis踩过的坑
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "- ...
- HTML,CSS,JS,DOM,jQuery
HTML 超链接访问顺序 a:link-->a:visited-->a:hover-->a:active.(有顺序) link:表示从未访问过的链接的样式 visited:表示已经访 ...
- 疫情在校学生之——用python对某校园热水服务app进行测试,实现自动免费用水(仅供参考)
写在前面的过场话: 本文只是对某校园热水服务app做个测试,其实本人并没有做大坏事,并未传播相关技术,文章以下内容的敏感部分会打码,并且相关厂商已经正在进行漏洞修复,大家看看就好.文章后会提供&quo ...
- NC24325 [USACO 2012 Mar S]Flowerpot
NC24325 [USACO 2012 Mar S]Flowerpot 题目 题目描述 Farmer John has been having trouble making his plants gr ...
- vue 项目知识
Vue使用 Vue 源码解析 Vue SSR 如何调试Vue 源码 如何学习开源框架---> 从它的第一次commit 开始看 国外的文章 大致了解写框架的过程(英文关键字) 找到关键---&g ...
- 下载Chrome离线安装包
https://www.google.com/chrome/thankyou.html?standalone=1&platform=mac&installdataindex=defau ...
- SQLZOO练习三--SELECT within SELECT Tutorial
This tutorial looks at how we can use SELECT statements within SELECT statements to perform more com ...
- 2022-7-13 java_1 第七组 刘昀航
@ 目录 前言 一.一些基本的指令 二.java 1.java的三个版本 2.java特点 3.运行一个java程序 三.java的数据类型 1.java基本数据类型 2.强制转换的原理 3.八种基本 ...