博客
关于我
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架构与SQL的执行流程_2
查看>>
MySQL架构介绍
查看>>
MySQL架构优化
查看>>
mysql架构简介、及linux版的安装
查看>>
MySQL查看数据库相关信息
查看>>
MySQL查看表结构和表中数据
查看>>
MySQL查询优化:LIMIT 1避免全表扫描
查看>>
MySQL查询优化之索引
查看>>
mysql查询储存过程,函数,触发过程
查看>>
mysql查询总成绩的前3名学生信息
查看>>
mysql查询慢排查
查看>>
MySQL查询报错ERROR:No query specified
查看>>
mysql查询数据库储存数据的占用容量大小
查看>>
MySQL查询数据库所有表名及其注释
查看>>
MySQL查询数据表中数据记录(包括多表查询)
查看>>
MySQL查询结果排序
查看>>
MYSQL查询语句优化
查看>>
mysql查询语句能否让一个字段不显示出来_天天写order by,你知道Mysql底层执行原理吗?
查看>>
MySQL查询语句:揭秘专家秘籍,让你秒变数据库达人!
查看>>
mysql查询超时对PHP执行的影响
查看>>