Codeforces Round #475 Div. 2 A B C D
A - Splits
题意
将一个正整数拆分成若干个正整数的和,从大到小排下来,与第一个数字相同的数字的个数为这个拆分的权重。
问\(n\)的所有拆分的不同权重可能个数。
思路
全拆成1,然后每次将2个1换成1个2,即每次2的个数增加1。
共有1+n/2种。
Code
#include <bits/stdc++.h>
#define F(i, a, b) for (int i = (a); i < (b); ++i)
#define F2(i, a, b) for (int i = (a); i <= (b); ++i)
#define dF(i, a, b) for (int i = (a); i > (b); --i)
#define dF2(i, a, b) for (int i = (a); i >= (b); --i)
using namespace std;
typedef long long LL;
int main() {
int n;
scanf("%d", &n);
printf("%d\n", n/2+1);
return 0;
}
B - Messages
题意
收到报文的时刻报文价值为A,之后每秒其价值减少B。在某个时刻读某个报文即能得到该报文此时的价值;此外,每秒能获得的固定收益为当前报文数*C.
问最大收益。
思路
理解题意即可:每个报文的价值,即每秒减少B,增加C。
因此只需比较B与C,如果B大,则所有报文都收到立即读;否则全都堆到最后读。
Code
#include <bits/stdc++.h>
#define F(i, a, b) for (int i = (a); i < (b); ++i)
#define F2(i, a, b) for (int i = (a); i <= (b); ++i)
#define dF(i, a, b) for (int i = (a); i > (b); --i)
#define dF2(i, a, b) for (int i = (a); i >= (b); --i)
using namespace std;
typedef long long LL;
int main() {
int n,a,b,c,T;
scanf("%d%d%d%d%d",&n,&a,&b,&c,&T);
int x, sum=0;
F(i, 0, n) scanf("%d", &x), sum += x;
LL ans = n*a;
if (c>b) ans += 1LL*(c-b)*(n*T-sum);
printf("%d\n", ans);
return 0;
}
C - Alternating Sum
题意
计算\(\sum \limits_{i=0}^{n} s_{i} a^{n - i} b^{i}\),其中系数\(s\)只取\(\pm1\),且为周期函数,周期为\(T=\frac{n+1}{k}\).
思路
即计算\(\sum \limits_{i=0}^{k-1} s_{i} a^{n - i} b^{i}\cdot\frac{q^{\frac{n+1}{k}}-1}{q-1}\),注意特判\(q=1\).
Code
#include <bits/stdc++.h>
#define F(i, a, b) for (int i = (a); i < (b); ++i)
#define F2(i, a, b) for (int i = (a); i <= (b); ++i)
#define dF(i, a, b) for (int i = (a); i > (b); --i)
#define dF2(i, a, b) for (int i = (a); i >= (b); --i)
using namespace std;
typedef long long LL;
const LL mod = 1e9+9;
LL poww(LL a, LL b) {
LL ret = 1;
while (b) {
if (b & 1) (ret *= a) %= mod;
(a *= a) %= mod;
b >>= 1;
}
return ret;
}
inline LL mul(LL a, LL b) { return a * b % mod; }
inline LL add(LL a, LL b) { return (a+b+mod) % mod; }
#define maxn 100010
char s[maxn];
int main() {
int n, a, b, k;
scanf("%d%d%d%d", &n, &a, &b, &k);
scanf("%s", s);
LL aa = poww(a, n), bb = 1, inva = poww(a, mod-2), ans = 0;
F(i, 0, k) {
int sign = s[i]=='+' ? 1 : -1;
ans = add(ans, sign*mul(aa, bb));
aa = mul(aa, inva);
bb = mul(bb, b);
}
LL q = mul(poww(b, k), poww(inva, k));
int cnt = (n+1) / k;
if (q == 1) ans = mul(ans, cnt);
else ans = mul(ans, mul(poww(q, cnt)-1, poww(q-1, mod-2)));
printf("%I64d\n", ans);
return 0;
}
D - Destruction of a Tree
题意
在树上删点,当且仅当该点的度数为偶数时才能删去,问能否删完图中所有点,并要求给出操作序列。
思路
从叶子开始从下往上考虑,显然叶子不能直接删,要删叶子必然要在删去其父亲节点之后进行。
而其父亲能不能直接删呢?如果其有奇数个孩子(未被删去的),则可以直接删去该节点(因其关联的边为连向其奇数个孩子+其父亲的共偶数条边),然后再向下删去之前未删去的部分;否则,其的删除工作必然要留到其父亲被删除之后才能进行。(注意,叶子节点也是符合这个特性的,因为叶子节点的孩子数0为偶数)
因此,dfs,从下往上考虑每个节点有多少个孩子未被删去;若为奇数个,则可删去该节点(并一路往下删孩子),并且忽略该节点对其父亲节点度数的贡献;否则,继续一路向上。
Code
#include <bits/stdc++.h>
#define F(i, a, b) for (int i = (a); i < (b); ++i)
#define F2(i, a, b) for (int i = (a); i <= (b); ++i)
#define dF(i, a, b) for (int i = (a); i > (b); --i)
#define dF2(i, a, b) for (int i = (a); i >= (b); --i)
#define maxn 200010
using namespace std;
typedef long long LL;
struct Edge {
int to, ne;
}edge[maxn<<1];
int ne[maxn], tot, rt;
bool flag[maxn];
vector<int> ans;
void add(int u, int v) {
edge[tot] = {v, ne[u]};
ne[u] = tot++;
}
void collect(int u, int fa) {
ans.push_back(u);
flag[u] = true;
for (int i = ne[u]; ~i; i = edge[i].ne) {
int v = edge[i].to;
if (v == fa || flag[v]) continue;
collect(v, u);
}
}
int dfs(int u, int fa) {
int tot = 0;
for (int i = ne[u]; ~i; i = edge[i].ne) {
int v = edge[i].to;
if (v == fa) continue;
tot += dfs(v, u);
}
if ((u==rt&&!(tot&1)) || (u!=rt&&tot&1)) collect(u, fa);
return !(tot&1);
}
int main() {
memset(ne, -1, sizeof ne);
int n, x;
scanf("%d", &n);
F2(i, 1, n) {
scanf("%d", &x);
if (!x) rt = i;
else add(i, x), add(x, i);
}
if (dfs(rt, -1)) {
puts("YES");
for (auto x : ans) printf("%d\n", x);
}
else puts("NO");
return 0;
}
Codeforces Round #475 Div. 2 A B C D的更多相关文章
- Tinkoff Internship Warmup Round 2018 and Codeforces Round #475 (Div. 1) 963B 964D B Destruction of a Tree
题 OvO http://codeforces.com/contest/963/problem/B CF 963B 964D 解 对于题目要求,显然一开始的树,要求度数为偶数的节点个数为奇数个,通过奇 ...
- Codeforces Round #475 Div. 1
B:当n是偶数时无解,因为此时树中有奇数条边,而我们每次都只能删除偶数条.当n是奇数时一定有解,因为此时不可能所有点度数都为奇数,只要找到一个度数为偶数的点,满足将它删掉后,各连通块大小都为奇数就可以 ...
- Tinkoff Internship Warmup Round 2018 and Codeforces Round #475 (Div. 1)D. Frequency of String
题意:有一个串s,n个串模式串t,问s的子串中长度最小的包含t k次的长度是多少 题解:把所有t建ac自动机,把s在ac自动机上匹配.保存每个模式串在s中出现的位置.这里由于t两两不同最多只有xsqr ...
- Codeforces Round #475 (Div. 2) C - Alternating Sum
等比数列求和一定要分类讨论!!!!!!!!!!!! #include<bits/stdc++.h> #define LL long long #define fi first #defin ...
- Codeforces Round #475 (Div. 2) D. Destruction of a Tree
题意:给你一棵树, 只能删度数为偶数的点, 问你能不能将整个图删完, 如果能输入删除的顺序. 思路:对于一棵树来说, 如果里面的点的个数是偶数个则肯定不可能, 偶数个点有奇数条边,而你每次删只能删偶数 ...
- Codeforces Round #475 (Div. 2)
B. Messages 题意:有n个消息分别在ti的时候收到.设所有消息收到时初始值为A,每过一秒,其值减去B.当在某一秒选择读某个消息时,获值为当前消息的值:如果在某一秒结束的时候,手上有k则消息未 ...
- Tinkoff Internship Warmup Round 2018 and Codeforces Round #475 (Div. 2)
A. Splits time limit per test 1 second memory limit per test 256 megabytes input standard input outp ...
- Tinkoff Internship Warmup Round 2018 and Codeforces Round #475 (Div. 1)
A. Alternating Sum 就是个等比数列,特判公比为 $1$ 的情况即可. #include <bits/stdc++.h> using namespace std; ; ; ...
- 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 ...
随机推荐
- MySQL☞length函数
length(字符串/列名):求出该字符串/列名中字符的个数 格式: select length(列名) from 表名 如下图:
- Kubernetes实战 高可用集群搭建,配置,运维与应用
1-1 K8S导学 1-2 搭建K8S集群步骤和要点介绍 1-3 搭建三节点Ubuntu环境 1-4 安装容器引擎 1-5 下载Kubeadm.node组件和命令行工具 1-6 向集群中加入worke ...
- Python简要标准库(3)
shelve 若只需要一个简单的存储方案,那么shelve模块可以满足你大部分的需要,你所需要的只是为它提供文件名.shelve中唯一有趣的函数是open,在调用的时候他会返回一个Shelf对象 注意 ...
- 核方法(Kernel Methods)
核方法(Kernel Methods) 支持向量机(SVM)是机器学习中一个常见的算法,通过最大间隔的思想去求解一个优化问题,得到一个分类超平面.对于非线性问题,则是通过引入核函数,对特征进行映射(通 ...
- truffle的调用nodeJs的问题
Truffle3.0集成NodeJS并完全跑通(附详细实例,可能的错误) 升级到Truffle3.0 如果之前安装的是Truffle2.0版本,需要主动升级到Truffle3.0,两者的语法变化有点大 ...
- 以太坊remix IDE安装步骤
Remix 以太坊Solidity IDE搭建与初步使用 以太坊: 因为以太坊为开源社区,虽然东西很优秀,但是组件十分的杂乱,因此首先简单介绍下以太坊的一些常用组件: Geth: Geth是由以太坊基 ...
- 【SSH】——Struts2中的动态方法调用(二)
当action中的方法有很多时,那应该怎么调用呢?上次我们提到的UserAction类中只有一个execute方法,如果我们需要增加用户的增删改查方法,如下: public class UserAct ...
- java-2018-01-17计划
1.一句英语 包括单词 2.一个java版本的设计模式 参考:https://github.com/iluwatar/java-design-patterns 学习了抽象工厂模式 总结:java的RS ...
- 通过NTP(Network Time Protocal)协议进行时间同步
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAwUAAAKOCAYAAAD3ZbXWAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjw
- 【bzoj4070】[Apio2015]雅加达的摩天楼 set+堆优化Dijkstra
题目描述 印尼首都雅加达市有 N 座摩天楼,它们排列成一条直线,我们从左到右依次将它们编号为 0 到 N−1.除了这 N 座摩天楼外,雅加达市没有其他摩天楼. 有 M 只叫做 “doge” 的神秘生物 ...