Codeforces Round 957 (Div. 3)
题目链接:Codeforces Round 957 (Div. 3)
总结:E不懂,F差一个set去重
A. Only Pluses
fag:枚举
B. Angry Monk
fag:模拟
Solution:分裂的花费为\(a_i - 1\),添加的花费为\(a_i\)。
C. Gorilla and Permutation
fag:思维
Solution:大于等于\(k\)的数,逆序放在最前面,小于等于\(m\)的数,从最后面开始从大到小放,中间的位置任意放剩下的数。
void solve(){
cin >> n >> m >> k;
vector<int> a(n + 1);
int i, l, r;
for (i = n, l = 1; i >= k; i --, l ++)
a[l] = i;
for (i = m, r = n; i >= 1; i --, r --)
a[r] = i;
for (int i = l; i <= r; i ++){
a[i] = ++ m;
}
for (int i = 1; i <= n; i ++)
cout << a[i] << " \n"[i == n];
}
D. Test of Love
fag:DP
Solution:考虑如何从上一步转移,跳过来或者游过来。
- 注意\(m\)的范围,可以直接枚举前\(m\)个格子(赛时没看到范围,用单调队列优化DP做的)
- 游过来的前提,上一格是水。
void solve(){
cin >> n >> m >> k;
string s;
cin >> s;
s = "$" + s;
deque<int> qu;
vector<int> f(n + 2, INF);
f[0] = 0;
qu.push_back(0);
for (int i = 1; i <= n + 1; i ++){
if (s[i] == 'C')
continue;
while (qu.size() && qu.front() + m < i){ // 存储原木的坐标
qu.pop_front();
}
if (qu.size())
f[i] = f[qu.front()];
if (s[i - 1] == 'W')
f[i] = min(f[i], f[i - 1] + 1);
if (s[i] == 'L'){
while (qu.size() && f[qu.back()] >= f[i])
qu.pop_back();
qu.push_back(i);
}
}
if (f[n + 1] > k){
cout << "NO\n";
}
else{
cout << "YES\n";
}
}
E. Novice's Mistake
fag:思维
Desription:给定一个\(n\),求出所有满足条件的\(a, b\)组合。
- \(1 <= a <= 1e4, 1 <= n <= 100\)
- \(n * a - b\)等于将\(a\)个字符串\(n\)然后删去末尾\(b\)个字符之后代表的整数
- \(n * a - b > 0\)
Solution:注意到字符串的操作会影响答案的位数,但是数值计算\(n * a\)最多为\(1e6\)所以最大只有\(6\)位。
- 我们枚举\(a\),然后枚举答案的位数\(k\),对于每个\(k\)求出一个\(b\),判断当前\(a, b\)是否满足条件
Competing:赛场根本没想到位数的关系
void solve(){
string n;
cin >> n;
vector<pii> ans;
for (int a = 1; a <= 10000; a ++){
int len = to_string(stoi(n) * a).size(); // 当前位数
// if (a == 1262)
// debug(len);
for (int k = len; k; k --){
int b = a * n.size() - k;
if (!b)
continue;
int t = 0;
for (int i = 1, j = 0; i <= k; i ++){
if (j == n.size())
j = 0;
t = t * 10 + (n[j ++] - '0');
}
if (t == stoi(n) * a - b){
ans.push_back({a, b});
}
// if (a == 1262 && b == 2519){
// debug(t, stoi(n) * a - b);
// }
}
}
cout << ans.size() << endl;
for (auto [a, b] : ans){
cout << a << " " << b << endl;
}
}
F. Test of Love
fag:思维
Description:有\(n\)个数,给定一个\(x\),将\(n\)个数分为\(k\)个连续区间,每个区间满足任意一个子集的乘积不等于\(x\)。
1 <= n <= 1e5 2 <= x <= 1e5
1 <= a_i <= 2e5
Solution:从前往后模拟当前区间能够得到那些因数(使用set去重),因为因数的个数很少,所以可做
Competing:没考虑到使用\(set\)去重
void solve(){
int x;
cin >> n >> x;
vector<int> a(n);
set<int> v; // 记录当前区间所有可能出现的x的约数
for (int i = 0; i < n; i ++)
cin >> a[i];
int ans = 1;
for (int i = 0; i < n; i ++){
if (x % a[i])
continue;
set<int> tmp;
for (auto j : v){
tmp.ep(a[i] * j); // 记录能够构造出来的数
}
for (auto j : tmp){
if (x % j)
continue;
v.ep(j);
}
if (v.find(x) != v.end()){
ans ++;
v.clear();
}
v.ep(a[i]);
}
cout << ans << endl;
}
Codeforces Round 957 (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 开学了,时间少,水题就不写题解了,不水的题也不写这么详细了 ...
- 贪心+模拟 Codeforces Round #288 (Div. 2) C. Anya and Ghosts
题目传送门 /* 贪心 + 模拟:首先,如果蜡烛的燃烧时间小于最少需要点燃的蜡烛数一定是-1(蜡烛是1秒点一支), num[g[i]]记录每个鬼访问时已点燃的蜡烛数,若不够,tmp为还需要的蜡烛数, ...
随机推荐
- 2023NOIP A层联测9 T3 天竺葵
2023NOIP A层联测9 T3 天竺葵 题面及数据范围 Ps:连接为accoderOJ. 看题大概是一个最长上升子序列的带权版本,于是想到 dp. 设 \(dp[i][j]\) 为到第 \(i\) ...
- 19、解析2_1(链、chunk、锁)
解析 shared pool 图解: library cache里面,暂时可以认为存储着: 1.SQL以及对应的执行计划(所占空间比较小): 2.存储过程.函数.触发器.包,它们编译后的对象(所占空间 ...
- Thinkphp漏洞复现
Thinkphp漏洞复现 环境均为vulhub/thinkphp Thinkphp是一种开源框架.是一个由国人开发的支持windows/Unix/Linux等服务器环境的轻量级PHP开发框架. 很多c ...
- npm安装包出现Invalid Version,npm list报错UNMET DEPENDENCY报错
执行 npm install 出现报错 2097 verbose stack TypeError: Invalid Version: 2097 verbose stack at new SemVer ...
- java——棋牌类游戏斗地主(webddz1.0)之一
这是本人最近一段时间写的斗地主的java代码,大体框架都实现了,主要缺少,AI的智能算法. 本版本是在singleddz3.0的基础上修改的,修改为了网络版本. 主要修改代码如下: package c ...
- Docker之基础(一)
接触Docker有很久一段时间, 但是没有好好总结一下, 借此公司项目全面容器化, 记录一下常用的Docker操作 概况: 本次容器化的项目包括PHP+Python项目,PHP是基于php-fpm的基 ...
- Django之开发restful接口
django中的开发接口有两种模式FBV和CBV,分别是基于函数视图和基于类视图,详细的可以看看菜鸟教程的Django 视图 - FBV 与 CBV,由于本文的用户管理是一个restful风格的api ...
- PythonDay5Advance
PythonDay5Advance 函数和模块 main函数要有,用户自己选择要做的功能,根据选择调用不同的函数 用户注册的信息需要使用一个文件存储,登录需要判断用户是否存在,密码是否正确 注册的时候 ...
- Electron包下载经常失败或太慢问题
前情 Electron是很好的桌面端开发框架,公司有个桌面端项目就是基于Electron开发的. 坑 在项目初始化的时候,需要通过npm install安装项目需要依赖的模块,但是经常报Electro ...
- std的map或者set中,比较浮点类型二维三维数据
在map和set中,如果比较对象是二维或者三维数据,需要把二维三维数据的浮点数转换为比较精度. 如果比较精度是0.001,那么数据的精度也必须是0.001,不然会出现如下情况: 比较函数 struct ...