Codeforces Round Edu 36
A、B、C
略
D(dfs+强连通分量)
题意:
给出一个n(n<=500)点m(m<=100000)边的有向图,问能否通过删去一条边使得该图无环。
分析:
最简单的想法就是枚举一条边删去然后判断图是否有环,这样是O(m^2)的不能接受
仔细想想,如果图中环数<=1,则YES;如果图中环数>=2,那么只有当它们的交恰好是一条边时,才是YES,其它情况都是NO
所以我们首先可以通过dfs找到一个环(vis[u]=0,1,2分别表示点u没遍历到、遍历到了在栈里、遍历过了已经出栈了),然后枚举环上的边进行删除,然后判断剩余的图中是否有环即可
这样时间复杂度是O(n(n+m))的
至于判断是否有环,我们可以求强连通分量的数目,用bitset去优化,那么时间复杂度就是O(n*n*n/64)
E(离散化+线段树)
略
F(套路+并查集)
题意:
给你一个树(n<=2e6),每个点都有自己的点权,I(x,y)表示x与y路径之间的所有点最大值与最小值的差,求
分析:
将最大值与最小值分别计算,以最大值为例,即计算对于每个点u,有多少个点对过u并且以v[u]为最大值
这就是将序列上的经典问题推广到树上来,原来的序列上的这个问题我是用set做的,但这种方法不能推广到树上来
其实序列上的该问题还有一个套路,就是从小到大往对应位置上加,那么对于现在刚加入的x,能凑成区间包含他作为最大值的一定是x左边连续存在的点和x右边连续存在的点,这我们可以用并查集来维护
推广到树上,现在从小到大加入x,那么能过x的点对一定是在x周围那些连续存在的点里面挑,这也可以用并查集来完成,不断把x的集合与四周相邻点的集合merge就行了
void merge(int x,int y,int value)
{
if(!f[x]||!f[y]) return;
x=find(x),y=find(y);
s+=1LL*sz[x]*sz[y]*value;
f[x]=y;
sz[y]+=sz[x];
}
long long solve()
{
for(int i=;i<=n;++i) pos[i]=i;
sort(pos+,pos+n+,cmp);
for(int i=;i<=n;++i) f[i]=,sz[i]=;
s=;
for(int i=;i<=n;++i)
{
int x=pos[i];
f[x]=x,sz[x]=;
for(int j=;j<g[x].size();++j) merge(x,g[x][j],a[x]);
}
return s;
}
G(莫比乌斯反演)
题意:
给定一个n和k(均不超过2e6),定义b(i)表示gcd(a1,a2,...,an)=1的序列个数,其中1<=ai<=i,现在要求出b(1) b(2) ... b(k)
分析:
我们先确定上界i,那么F(x)表示gcd是x倍数的序列个数,f(x)表示gcd是x的序列个数
显然F(x)=[i/x]^n
那么有F(d)=Σf(n) (d|n) ,反演一下有f(d)=Σμ(n/d)F(n) (d|n)
那么b(i)=f(1)=Σμ(j)F(j) (1<=j<=i)
那么对于确定上界i,我们就通过莫比乌斯反演求出了b(i)的值,但我们现在要求出所有的b(1) .. b(k)
我们考察相邻的b(i-1)和b(i),发现[i/x]^n和[(i-1)/x]^n不一样当且仅当i是n的因数
于是我们可以枚举因数,做出每一项与前一项的差值,然后求个前缀和就可以得到每一个b(i)了
时间复杂度O(klogk)
Codeforces Round Edu 36的更多相关文章
- CodeForces Round
CodeForces Round 199 Div2 完了,这次做扯了,做的时候有点发烧,居然只做出来一道题,差点被绿. My submissions # When Who Problem ...
- Codeforces Codeforces Round #484 (Div. 2) D. Shark
Codeforces Codeforces Round #484 (Div. 2) D. Shark 题目连接: http://codeforces.com/contest/982/problem/D ...
- Codeforces Round #452 (Div. 2) A B C
Codeforces Round #452 (Div. 2) A Splitting in Teams 题目链接: http://codeforces.com/contest/899/problem/ ...
- Educational Codeforces Round 71 (Rated for Div. 2)-E. XOR Guessing-交互题
Educational Codeforces Round 71 (Rated for Div. 2)-E. XOR Guessing-交互题 [Problem Description] 总共两次询 ...
- Codeforces Round #519 by Botan Investments(前五题题解)
开个新号打打codeforces(以前那号玩废了),结果就遇到了这么难一套.touristD题用了map,被卡掉了(其实是对cf的评测机过分自信),G题没过, 700多行代码,码力惊人.关键是这次to ...
- Codeforces Round #781(C. Tree Infection)
Codeforces Round #781 C. Tree Infection time limit per test 1 second memory limit per test 256 megab ...
- Codeforces Round #366 (Div. 2) ABC
Codeforces Round #366 (Div. 2) A I hate that I love that I hate it水题 #I hate that I love that I hate ...
- Codeforces Round #354 (Div. 2) ABCD
Codeforces Round #354 (Div. 2) Problems # Name A Nicholas and Permutation standard input/out ...
- Codeforces Round #368 (Div. 2)
直达–>Codeforces Round #368 (Div. 2) A Brain’s Photos 给你一个NxM的矩阵,一个字母代表一种颜色,如果有”C”,”M”,”Y”三种中任意一种就输 ...
随机推荐
- Spotlight安装
刚才技术群的一个朋友在安装Spotligh出现了一些问题,所以本人临时写个简单的教程 1.下载安装包(安装包地址:https://pan.baidu.com/s/1c2tmqyc),解压,然后傻瓜式安 ...
- (转)Spring的bean管理(注解方式)
http://blog.csdn.net/yerenyuan_pku/article/details/69663779 Spring的bean管理(注解方式) 注解:代码中的特殊标记,注解可以使用在类 ...
- Vue之组件的生命周期
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- xshell全局设置配色方案
新建XTerm1.xcs文件,将以下内容黏贴进去,保存退出 [XTerm] text=839496 cyan(bold)=93a1a1 text(bold)=408080 magenta=dd3682 ...
- spring mvc poi excel
Util类 package com.common.util; public class ExportUtil { private XSSFWorkbook wb = null; private XSS ...
- IOS学习笔记1—Iphone程序运行流程
Iphone程序运行流程 main.m文件,iOS应用程序的主入口 main函数的两个参数为命令行参数,在ios开发中不会用到这些元素,包括这两个参数是为了与标准ANSI C保持一致 UIApplic ...
- NodeJs运行服务器-day01
//读取内置模块http,这个模块开发服务器用的var http =require('http'); var server=http.createServer(function(req,res){ r ...
- noip2019——动态规划刷题历程
加粗的是值得总结的 从洛谷的普及题开始刷题: 背包式dp(有些技巧的) 1.p2639[USACO09OCT]Bessie的体重问题 -p1049取模意义下01背包 技巧:重量=价值 2.金明的预算问 ...
- 如何让线程A等待B执行结束后执行?
1. 使用条件变量 判断是否任务B已经做完,然后再执行任务A. 测试代码可看:https://blog.csdn.net/guochao6531/article/details/78075882 2. ...
- for、while循环
for循环 # for 循环后面可以对Iterable或者Iterator进行遍历 # "abc"和[1,2,3]为可迭代对象,range(4)为迭代器 for i in &quo ...