博客
关于我
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/

你可能感兴趣的文章
MySQL中的时间函数
查看>>
mysql中的约束
查看>>
MySQL中的表是什么?
查看>>
mysql中穿件函数时候delimiter的用法
查看>>
Mysql中索引的分类、增删改查与存储引擎对应关系
查看>>
Mysql中索引的最左前缀原则图文剖析(全)
查看>>
MySql中给视图添加注释怎么添加_默认不支持_可以这样取巧---MySql工作笔记002
查看>>
Mysql中获取所有表名以及表名带时间字符串使用BetweenAnd筛选区间范围
查看>>
Mysql中视图的使用以及常见运算符的使用示例和优先级
查看>>
Mysql中触发器的使用示例
查看>>
Mysql中设置只允许指定ip能连接访问(可视化工具的方式)
查看>>
mysql中还有窗口函数?这是什么东西?
查看>>
mysql中间件
查看>>
MYSQL中频繁的乱码问题终极解决
查看>>
MySQL为Null会导致5个问题,个个致命!
查看>>
MySQL为什么不建议使用delete删除数据?
查看>>
MySQL主从、环境搭建、主从配制
查看>>
Mysql主从不同步
查看>>
mysql主从同步及清除信息
查看>>
MySQL主从同步相关-主从多久的延迟?
查看>>