博客
关于我
Educational Codeforces Round 37 (Rated for Div. 2)
阅读量:323 次
发布时间:2019-03-03

本文共 850 字,大约阅读时间需要 2 分钟。

前言

昨晚打了一场CF,战绩不太好,只写了ABCFG,赛后更正了E

在这里写一下题解

A

二分答案,直接判断

B

直接模拟即可

C

考虑到连续一段1里面事可以互换的,暴力扫一次即可

D

没做

E

题意:给你一个完全图,删去若干跳变,询问有多少个联通块

思路比较好的一道题,考试的时候没有想出来
对于每一个点,扫所有点,如果它们之间有边,就合并成一个联通快
扫的时候就扫没有合并的点
考虑到每一次合并,点数会少1,所以这个过程是O(n)的
然后再考虑点数不会边的情况,就是有边,这个过程是O(m)的
于是总体复杂度是O(n+m)的
CODE:

#include
#include
#include
#include
#include
#include
using namespace std;const int N=200005;int n,m;vector
e[N];int f[N];//并查集bool vis[N];int cnt;vector
ans[N];int find (int x){ return f[x]==x?x:f[x]=find(f[x]);}void dfs (int x){ /*printf("%d\n",x); system("pause");*/ vis[x]=true; ans[cnt].push_back(x); f[x]=x+1; int i=0; for (int u=find(1);u<=n;u=find(u+1)) { while (i

F

这题的话,先线性筛出所有数的约数个数

然后考虑到,一个数n的约数个数是不超过 n n
所以修改的次数不会很多,就5,6次左右
变到2,1就不会变了
再线段树上打标记即可

G

先分解质因数

二分答案,然后容斥得到个数就可以了

转载地址:http://ppcq.baihongyu.com/

你可能感兴趣的文章
MSCRM调用外部JS文件
查看>>
MSEdgeDriver (Chromium) 不适用于版本 >= 79.0.313 (Canary)
查看>>
MsEdgeTTS开源项目使用教程
查看>>
msf
查看>>
MSSQL数据库查询优化(一)
查看>>
MSSQL数据库迁移到Oracle(二)
查看>>
MSSQL日期格式转换函数(使用CONVERT)
查看>>
MSTP多生成树协议(第二课)
查看>>
MSTP是什么?有哪些专有名词?
查看>>
Mstsc 远程桌面链接 And 网络映射
查看>>
Myeclipse常用快捷键
查看>>
MyEclipse更改项目名web发布名字不改问题
查看>>
MyEclipse用(JDBC)连接SQL出现的问题~
查看>>
mt-datetime-picker type="date" 时间格式 bug
查看>>
myeclipse的新建severlet不见解决方法
查看>>
MyEclipse设置当前行背景颜色、选中单词前景色、背景色
查看>>
Mtab书签导航程序 LinkStore/getIcon SQL注入漏洞复现
查看>>
myeclipse配置springmvc教程
查看>>
MyEclipse配置SVN
查看>>
MTCNN 人脸检测
查看>>