[CF]Round511
这场比赛我及时的参加了,但是打的时候状态实在是太烂了,只做出来了Div2的AB题。
A Little C loves 3 I
直接构造就行。
B Cover Points
应该很容易就看出来这个等腰三角形的腰是坐标轴,然后就用\(y=b-x\)的一次函数往上套就行了。
C Enlarge GCD
这个题比赛的时候我交了4次,没有一次想到要先除gcd的。实际上在赛场上我已经接近正解了,就是枚举素因子,然后把最多的那个留着,其他的删掉就好了啊。
好吧,说起来简单,真正要把代码写到AC还是要看std的(摔
话说std的码都好短啊。
Code:
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <vector>
const int N = 15000000+10;
const int M = 3e5 + 10;
int pri[N], notp[N], sz;
int n, d[N], a[M];
void get_pri() {
notp[1] = 1;
for (int i = 2; i < N; ++i) {
if (!notp[i]) notp[i] = pri[++sz] = i;
for (int j = 1; j <= sz; ++j) {
int k = i * pri[j];
if (k >= N) break;
notp[k] = pri[j];
if (i % pri[j] == 0) break; // 我这里竟然写错了
}
}
}
int gcd(int x, int y) { return !y?x:gcd(y, x%y); }
int main() {
scanf("%d", &n);
get_pri();
int Gcd = 0;
for (int i = 1; i <= n; ++i) {
scanf("%d", &a[i]);
Gcd = gcd(a[i], Gcd);
}
int ans = 0;
for (int i = 1, x; i <= n; ++i) {
for (int j = a[i]/Gcd; j > 1; )
for (++d[x = notp[j]]; notp[j] == x;) j /= notp[j];
}
for (int i = 1; i < N; ++i) ans = std::max(ans, d[i]);
printf("%d\n", !ans ? -1 : n - ans);
return 0;
}
D Little C Loves 3 II
一道鬼畜的找规律的题,有点小凯的疑惑的感觉。这个题没啥意思。
E Region Separation
这个题是一道真正的好题。
首先我们确定这个国家能否被分成\(k\)个level-2的区域,这其实并不难,设总和为\(S\),那么每一块的和应该是\(S/k\),我们从叶子节点开始考虑,记一个节点\(i\)及其子树的和为\(S_i\),每次遇到一个\(S_i = S/k\)的节点就把它和它的子树分出去,这样,我们容易发现,只有\(S_i \equiv 0 (\bmod \dfrac{S}{k})\)的节点有可能被分出去。因此,至少要有\(k\)个节点满足这个条件才有可能把这个国家分成\(k\)份。由于所有的数都是正的,所以也可以推出至多有\(k\)个节点满足这个条件。那么我们就只用考虑有多少个\(k\)满足这个条件了,化简那个条件可以得到\(k\)是\(\dfrac{S}{\gcd (S, S_i)}\)的整数倍(这个有点靠直觉),然后就能DP求\(k\)是否是一个合法的解。
然后就可以得出这样的结论:level-i可以被划分为\(k_i\)个部分当且仅当level-2可以被划分为\(k_i\)个部分且\(k_{i-1}\mid k_i\)(这里稍微有点绕,就是要注意每层的每个区域的权值和相等这个条件),然后就可以DP了,设\(F_i\)为最后一层有\(i\)个区域的方案数,通过枚举\(i\)的倍数来转移就好了。
Code:
#include <cstdio>
typedef long long LL;
const int N = 1e6 + 10;
const LL MOD = 1e9 + 7;
int n, fa[N];
LL s[N], f[N], F[N];
LL gcd(LL x, LL y) { return !y?x:gcd(y, x%y); }
int main() {
scanf("%d", &n);
for (int i = 1; i <= n; ++i) scanf("%d", &s[i]);
for (int i = 2; i <= n; ++i) {
scanf("%d", &fa[i]);
}
for (int i = n; i; --i) s[fa[i]] += s[i];
for (int i = n; i; --i) {
LL x = s[1] / gcd(s[1], s[i]);
if (x <= n)
++f[x];
}
for (int i = n; i; --i) {
for (int j = i; (j+=i) <= n; ) f[j] += f[i];
}
F[1] = 1;
LL ans = 0;
for (int i = 1; i <= n; ++i) {
if (f[i] == i) {
ans = (ans + F[i]) % MOD;
for (int j = i; (j+=i) <= n; ) F[j] = (F[j] + F[i]) % MOD;
}
}
printf("%lld\n", ans);
return 0;
}
Div1剩下的那两道题先咕着吧
[CF]Round511的更多相关文章
- ORA-00494: enqueue [CF] held for too long (more than 900 seconds) by 'inst 1, osid 5166'
凌晨收到同事电话,反馈应用程序访问Oracle数据库时报错,当时现场现象确认: 1. 应用程序访问不了数据库,使用SQL Developer测试发现访问不了数据库.报ORA-12570 TNS:pac ...
- cf之路,1,Codeforces Round #345 (Div. 2)
cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅..... ...
- cf Round 613
A.Peter and Snow Blower(计算几何) 给定一个点和一个多边形,求出这个多边形绕这个点旋转一圈后形成的面积.保证这个点不在多边形内. 画个图能明白 这个图形是一个圆环,那么就是这个 ...
- ARC下OC对象和CF对象之间的桥接(bridge)
在开发iOS应用程序时我们有时会用到Core Foundation对象简称CF,例如Core Graphics.Core Text,并且我们可能需要将CF对象和OC对象进行互相转化,我们知道,ARC环 ...
- [Recommendation System] 推荐系统之协同过滤(CF)算法详解和实现
1 集体智慧和协同过滤 1.1 什么是集体智慧(社会计算)? 集体智慧 (Collective Intelligence) 并不是 Web2.0 时代特有的,只是在 Web2.0 时代,大家在 Web ...
- CF memsql Start[c]UP 2.0 A
CF memsql Start[c]UP 2.0 A A. Golden System time limit per test 1 second memory limit per test 256 m ...
- CF memsql Start[c]UP 2.0 B
CF memsql Start[c]UP 2.0 B B. Distributed Join time limit per test 1 second memory limit per test 25 ...
- CF #376 (Div. 2) C. dfs
1.CF #376 (Div. 2) C. Socks dfs 2.题意:给袜子上色,使n天左右脚袜子都同样颜色. 3.总结:一开始用链表存图,一直TLE test 6 (1)如果需 ...
- CF #375 (Div. 2) D. bfs
1.CF #375 (Div. 2) D. Lakes in Berland 2.总结:麻烦的bfs,但其实很水.. 3.题意:n*m的陆地与水泽,水泽在边界表示连通海洋.最后要剩k个湖,总要填掉多 ...
随机推荐
- oracle分组后取最新的记录
使用Group By来实现取最新记录,需要注意一个问题,如果最大时间相同的数据都会被取出来. PS:即使数据字段类型是timestamp,也会登录相同的时间的数据. select A.* from A ...
- day 15 内置函数
内置函数 不用def定义能直接用的函数,带括号的 locals() # 返回本地作用域中的所有名字 globals() # 返回全局作用域中的所有名字 global 变量 nonlocal 变量 迭代 ...
- 剑指offer-面试题32-分行从上到下打印二叉树-二叉树遍历
/* 题目: 分行按层自上向下打印二叉树. */ /* 思路: 使用队列,将节点压入队列中,再弹出来,压入其左右子节点,循环,直到栈为空. 添加两个计数器,current记录当前行的节点数,next记 ...
- PTA 符号配对 —— C++
请编写程序检查C语言源程序中下列符号是否配对:/*与 */.(与 ).[与].{与}. 输入格式: 输入为一个C语言源程序.当读到某一行中只有一个句点.和一个回车的时候,标志着输入结束.程序中需要检查 ...
- 【转】为什么使用length获取Java数组的长度
记得vamcily 曾问我:“为什么获取数组的长度用.length(成员变量的形式),而获取String的长度用.length()(成员方法的形式)?” 我当时一听,觉得问得很有道理.做同样一件事情, ...
- Wannafly Winter Camp 2020 Day 6J K重排列 - dp
求 \(K\) 是多少个 \(n\) 元置换的周期.\(T\leq 100, n\leq 50, K \leq 10^{18}\) Solution 置换可以被试做若干个环组成的有向图,于是考虑 dp ...
- th:object、th:field、th:value 和 #dates.format 的冲突问题处理
若直接使用th:object 分解对象后,在搭配th:field="${#dates"使用#dates.format会抛出下面的异常: ---------------------- ...
- MVC开发之注入容器Ninject的使用
背景 在不使用注入容器之前,我们的项目往往存在着大量耦合的类,这使得我们在开发大型项目时难以维护.比如下面这个简单的MVC框架的例子,计算购物车的产品价格总和: /// <summary> ...
- 剑指offer-面试题11-旋转数组的最小数字-二分法
/* 题目: 把一个数组最开始的若干个元素搬到数组末尾,我们称之为数组的旋转. 输入一个递增排序的数组的旋转,输出旋转数组中的最小元素. */ /* 思路: 采用二分的方法,旋转数组实质上是上左半部分 ...
- Java后端API调用身份验证的思考
在如今信息泛滥的数字时代中对产品安全性的要求越来越高了,就比如说今天要讨论的Java后端API调用的安全性,在你提供服务的接口中一定要保证调用方身份的有效性和合法性,不能让非法的用户进行调用,避免数据 ...