Codeforces Round #636 (Div. 3)
比赛链接:https://codeforces.com/contest/1343
A - Candies
题意
有一数列 x + 2x + 4x + ... + 2k-1x = n,输出 k ≥ 2 时任一满足该等式的一个 x 值。
思路
等比数列求和得 (2k-1) x = n,枚举 k 即可。
代码
#include <bits/stdc++.h>
using namespace std; void solve() {
int n; cin >> n;
for (int i = 2; i < 32; i++) {
if (n % ((1 << i) - 1) == 0) {
cout << n / ((1 << i) - 1) << "\n";
return;
}
}
} int main() {
int t; cin >> t;
while (t--) solve();
}
B - Balanced Array
题意
构造一个数组,要求满足:
- 前一半为偶数,后一半为奇数
- 所有数两两不同且都为正整数
- 前一半的数之和与后一半的数之和相等
思路
贪心,从 2 起构造前一半,从 1 起构造后一半,后一半最后一个元素特别构造。
代码
#include <bits/stdc++.h>
using namespace std; void solve() {
int n; cin >> n;
n /= 2;
if (n & 1) cout << "NO" << "\n";
else {
cout << "YES" << "\n";
for (int i = 1; i <= n; i++) {
cout << 2 * i << ' ';
}
for (int i = 1; i <= n - 1; i++) {
cout << 2 * i - 1 << ' ';
}
cout << 3 * n - 1 << "\n";
}
} int main() {
int t; cin >> t;
while (t--) solve();
}
C - Alternating Subsequence
题意
在一个数组中寻找一个正负相间的最长的子序列,且该子序列元素之和为该长度所有子序列的最大值。
思路
长度优先——贪心地取所有不同正负的元素
最大和——同正负的元素利用双指针局部排序,每次取最大值
代码
#include <bits/stdc++.h>
using ll = long long;
using namespace std; void solve() {
int n; cin >> n;
ll a[n]; for (ll &i : a) cin >> i;
ll ans = 0;
for (int i = 0; i < n; ) {
int j = i + 1;
while (j < n and a[i] * a[j] > 0) ++j;
sort(a + i, a + j);
ans += a[j - 1];
i = j;
}
cout << ans << "\n";
} int main() {
int t; cin >> t;
while (t--) solve();
}
D - Constant Palindrome Sum
题意
对一个长度为偶数,元素大小在 [1, k] 之间的数组元素做变换,每次可以用 [1, k] 间的一个数替换一个元素,要求最终满足,所有的 a[i] + a[n - 1 - i] 相等 (0-indexed),求最少需要的变换次数。
思路
a[i] + a[n - 1 - i] 的范围为 [2, 2 * k],我们可以假设每个和一开始都需要变换所有元素,然后计算每个对称和所能变换的最小值和最大值,在此区间内的和只需变换两个元素中的一个,为了在线性时间内访问所有需要减一的区间,可以用一个差分数组记录每个需要变换区间的左右端点,最后对于初始时的和因为两个子元素都不用变换所以需要再减一。
代码
#include <bits/stdc++.h>
using namespace std; const int M = 4e5 + 100;
int n, k;
int a[M], cnt[M], sub[M]; void solve() {
cin >> n >> k;
for (int i = 0; i < n; i++) cin >> a[i];
for (int i = 2; i <= 2 * k; i++) cnt[i] = n, sub[i] = 0;
for (int i = 0; i < n / 2; i++) {
int x = a[i], y = a[n - 1 - i];
int mi = min(x, y) + 1;
int mx = max(x, y) + k;
--cnt[x + y];
--sub[mi];
++sub[mx + 1];
}
for (int i = 2; i <= 2 * k; i++) {
sub[i] += sub[i - 1];
cnt[i] += sub[i];
}
int ans = INT_MAX;
for (int i = 2; i <= 2 * k; i++)
ans = min(ans, cnt[i]);
cout << ans << "\n";
} int main() {
int t; cin >> t;
while (t--) solve();
}
Codeforces Round #636 (Div. 3)的更多相关文章
- 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 ...
- Codeforces Round #354 (Div. 2) ABCD
Codeforces Round #354 (Div. 2) Problems # Name A Nicholas and Permutation standard input/out ...
- Codeforces Round #368 (Div. 2)
直达–>Codeforces Round #368 (Div. 2) A Brain’s Photos 给你一个NxM的矩阵,一个字母代表一种颜色,如果有”C”,”M”,”Y”三种中任意一种就输 ...
- cf之路,1,Codeforces Round #345 (Div. 2)
cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅..... ...
- Codeforces Round #279 (Div. 2) ABCDE
Codeforces Round #279 (Div. 2) 做得我都变绿了! Problems # Name A Team Olympiad standard input/outpu ...
- Codeforces Round #262 (Div. 2) 1003
Codeforces Round #262 (Div. 2) 1003 C. Present time limit per test 2 seconds memory limit per test 2 ...
- Codeforces Round #262 (Div. 2) 1004
Codeforces Round #262 (Div. 2) 1004 D. Little Victor and Set time limit per test 1 second memory lim ...
- Codeforces Round #371 (Div. 1)
A: 题目大意: 在一个multiset中要求支持3种操作: 1.增加一个数 2.删去一个数 3.给出一个01序列,问multiset中有多少这样的数,把它的十进制表示中的奇数改成1,偶数改成0后和给 ...
- Codeforces Round #268 (Div. 2) ABCD
CF469 Codeforces Round #268 (Div. 2) http://codeforces.com/contest/469 开学了,时间少,水题就不写题解了,不水的题也不写这么详细了 ...
随机推荐
- 一文带你学会AQS和并发工具类的关系2
1.创建公平锁 1.使用方式 Lock reentrantLock = new ReentrantLock(true); reentrantLock.lock(); //加锁 try{ // todo ...
- Test typora
目录 0. test 0.5 easy test 1. problem 1 2. problem 2 3. problem 3 import numpy as np import matplotlib ...
- CTFshow萌新赛-web签到
打开靶机 查看页面信息 可以看到有一个system函数 在Linux中可以使用":"隔离不同的语句 payload如下 https://5105c8b6-83aa-4993-91b ...
- firewalld原理和基础命令
firewalld防火墙 Firewalld是什么? Firewalld提供了支持网络.防火墙定义网络看见以及接口安全等级的动态防火墙管理工具
- 1.搭建Hadoop实验平台
节点功能规划 操作系统:CentOS7.2(1511) Java JDK版本:jdk-8u65-linux-x64.tar.gz Hadoop版本:hadoop-2.8.3.tar.gz 下载地址: ...
- 不支持的字符集 (在类路径中添加 orai18n.jar): ZHS16GBK
不支持的字符集 (在类路径中添加 orai18n.jar): ZHS16GBK 报错图示: 报错内容: Exception in thread "main" java.sql.SQ ...
- aio 系列函数是由 POSIX 定义的异步操作接口,可惜的是,Linux 下的 aio 操作,不是真正的操作系统级别支持的,它只是由 GNU libc 库函数在用户空间借由 pthread 方式实现的,而且仅仅针对磁盘类 I/O,套接字 I/O 不支持。
30 | 真正的大杀器:异步I/O探索 https://time.geekbang.org/column/article/150780
- 栈 堆 stack heap 堆内存 栈内存 内存分配中的堆和栈 掌握堆内存的权柄就是返回的指针 栈是面向线程的而堆是面向进程的。 new/delete and malloc/ free 指针与内存模型
小结: 1.栈内存 为什么快? Due to this nature, the process of storing and retrieving data from the stack is ver ...
- 应答流式RPC 请求流式RPC 向流式RPC 流式RPC的三种具体形式
https://mp.weixin.qq.com/s/pWwSfXl71GQZ3KPmAHE_dA 用Python进行gRPC接口测试(二) 大帆船 搜狗测试 2020-02-07 上期回顾:用P ...
- Fody,告别烦人的INotifyPropertyChanged,最简方式实现通知!
INotifyPropertyChanged 我不是针对谁,我是说在座的各位 相信所有学wpf的,都写过类似下面的代码: 实现INotifyPropertyChanged public class M ...