Codeforces Round 895 (Div. 3)
B. The Corridor or There and Back Again
题解
- 考虑二分答案
- \(check\)时判断是否\(s_i \leq 2*(k - d_i),k\geq d_i\)
const int N = 2e5 + 10, M = 4e5 + 10;
int n, d[N], s[N];
bool check(int mid)
{
for (int i = 1; i <= n; ++i)
{
if (d[i] <= mid)
{
if (s[i] <= 2 * (mid - d[i]))
return false;
}
}
return true;
}
void solve()
{
cin >> n;
for (int i = 1; i <= n; ++i)
cin >> d[i] >> s[i];
int l = 1, r = 1e15;
while (l <= r)
{
int mid = l + r >> 1;
if (check(mid))
l = mid + 1;
else
r = mid - 1;
}
cout << r << endl;
}
C. Non-coprime Split
题解
- 容易发现一个大于1的非质数\(x\)一定可以由其约数\(y\)和\(x - y\)相加得到,且\(gcd(x-y,y)\neq1\)
- 直接暴力找大于1的非质数即可
const int N = 2e5 + 10, M = 4e5 + 10;
bool is_prime(int x, int &b)
{
if (x < 2)
return false;
for (int i = 2; i <= x / i; ++i)
{
if (x % i == 0)
{
b = i;
return false;
}
}
return true;
}
void solve()
{
int l, r;
cin >> l >> r;
int res = INF;
int b = -1;
for (int i = l; i <= r; ++i)
{
if (!is_prime(i, b) && i > 2)
{
res = i;
break;
}
}
if (res == INF)
cout << -1 << endl;
else
{
cout << b << " " << res - b << endl;
}
}
D. Plus Minus Permutation
题解
- 贪心考虑,对于整除\(x\)的位置一定从\(n\)开始放,对于整除\(y\)的位置一定从\(1\)开始放
- 但是存在同时整除\(x\)和\(y\)的情况
- 求出\(lcm(x,y)\),即可得到重合的位置数量\(n/lcm(x,y)\)
- 减去重合的位置数量后等差数列求和即可
const int N = 2e5 + 10, M = 4e5 + 10;
int n, x, y;
void solve()
{
cin >> n >> x >> y;
int t1 = n / x, t2 = n / y;
int lc = lcm(x, y);
int t3 = n / lc;
t1 -= t3, t2 -= t3;
cout << (n - t1 + 1 + n) * t1 / 2 - (1 + t2) * t2 / 2 << endl;
}
E. Data Structures Fan
题解
- 不会思维,赛时直接上线段树了
- 线段树维护区间二进制为\(0\)的位置上的异或和\(ans0\),区间二进制为\(0\)的位置上的异或和\(ans1\)
- 考虑区间反转操作:直接交换\(ans0\)和\(ans1\)即可,并打上懒惰标记
const int N = 1e5 + 10, M = 4e5 + 10;
int n, q, a[N];
string s;
struct info
{
int ans0, ans1;
friend info operator+(const info &a, const info &b)
{
info c;
c.ans0 = a.ans0 ^ b.ans0;
c.ans1 = a.ans1 ^ b.ans1;
return c;
}
};
struct SEG
{
int lazy;
info val;
} seg[N << 2];
void up(int id)
{
seg[id].val = seg[lson].val + seg[rson].val;
}
void settag(int id, int tag)
{
swap(seg[id].val.ans0, seg[id].val.ans1);
seg[id].lazy ^= tag;
}
void down(int id)
{
if (seg[id].lazy == 0)
return;
settag(lson, seg[id].lazy);
settag(rson, seg[id].lazy);
seg[id].lazy = 0;
}
void build(int id, int l, int r)
{
seg[id].lazy = 0;
if (l == r)
{
if (s[l] == '1')
{
seg[id].val.ans0 = 0;
seg[id].val.ans1 = a[l];
}
else
{
seg[id].val.ans0 = a[l];
seg[id].val.ans1 = 0;
}
return;
}
int mid = l + r >> 1;
build(lson, l, mid);
build(rson, mid + 1, r);
up(id);
}
void modify(int id, int l, int r, int ql, int qr, int tag)
{
if (ql <= l && r <= qr)
{
settag(id, tag);
return;
}
down(id);
int mid = l + r >> 1;
if (qr <= mid)
modify(lson, l, mid, ql, qr, tag);
else if (ql > mid)
modify(rson, mid + 1, r, ql, qr, tag);
else
{
modify(lson, l, mid, ql, qr, tag);
modify(rson, mid + 1, r, ql, qr, tag);
}
up(id);
}
info query(int id, int l, int r, int ql, int qr)
{
if (ql <= l && r <= qr)
return seg[id].val;
down(id);
int mid = l + r >> 1;
if (qr <= mid)
return query(lson, l, mid, ql, qr);
else if (ql > mid)
return query(rson, mid + 1, r, ql, qr);
else
return query(lson, l, mid, ql, qr) + query(rson, mid + 1, r, ql, qr);
}
void solve()
{
cin >> n;
for (int i = 1; i <= n; ++i)
cin >> a[i];
cin >> s;
s = " " + s;
build(1, 1, n);
cin >> q;
while (q--)
{
int op, l, r, g;
cin >> op;
if (op == 1)
{
cin >> l >> r;
modify(1, 1, n, l, r, 1);
}
else
{
cin >> g;
if (g == 0)
cout << query(1, 1, n, 1, n).ans0 << " ";
else
cout << query(1, 1, n, 1, n).ans1 << " ";
}
}
cout << endl;
}
F. Selling a Menagerie
题解
- 跑个拓扑排序,不在环上的随便放,然后对每个环上的从每个起点都跑一次找到贡献最大的起点
- 枚举起点的过程类似滑动窗口更新即可
- 可以断环成链方便一点
const int N = 1e5 + 10, M = 4e5 + 10;
int n, a[N], c[N], deg[N], vis[N], b[N];
vector<int> g[N];
void dfs(int u, vector<int> &vec)
{
vis[u] = true;
vec.push_back(u);
for (auto v : g[u])
{
if (!vis[v])
dfs(v, vec);
}
}
void solve()
{
cin >> n;
for (int i = 1; i <= n; ++i)
g[i].clear(), deg[i] = vis[i] = 0;
for (int i = 1; i <= n; ++i)
{
cin >> a[i];
g[i].push_back(a[i]);
deg[a[i]]++;
}
for (int i = 1; i <= n; ++i)
cin >> c[i];
queue<int> q;
for (int i = 1; i <= n; ++i)
{
if (deg[i] == 0)
q.push(i);
}
vector<int> ans;
while (q.size())
{
int u = q.front();
vis[u] = true;
q.pop();
ans.push_back(u);
for (auto v : g[u])
{
if (--deg[v] == 0)
q.push(v);
}
}
for (int i = 1; i <= n; ++i)
{
vector<int> vec;
if (vis[i])
continue;
if (!vis[i])
dfs(i, vec);
int mx = 0, pos = 1, idx = 0;
for (auto x : vec)
b[++idx] = x;
for (int i = 1; i <= idx; ++i)
b[i + idx] = b[i];
int sum = 0;
for (int i = 1; i <= idx - 1; ++i)
sum += 2 * c[b[i]];
sum += c[b[idx]];
mx = sum;
for (int i = 2; i <= idx; ++i)
{
sum -= c[b[i - 1]];
sum += c[b[i + idx - 1 - 1]];
if (mx < sum)
{
sum = mx;
pos = i;
}
}
for (int i = pos; i <= pos + idx - 1; ++i)
ans.push_back(b[i]);
}
for (auto u : ans)
cout << u << " ";
cout << endl;
}
G. Replace With Product
题解
- 首先序列两边的\(1\)完全可以用来加,所以我们处理出左边第一个不是\(1\)的位置\(l\),同理处理出\(r\)
- 从位置\(l\)开始乘,设\(res\)为乘积
- 如果乘到某个位置\(x\)时\(res\geq 1e9\),容易证明:对于区间\([x + 1, r]\)里面的数字,乘起来的和一定由于加起来的和
- 所以\([l,r]\)这段区间我们可以全选
- 如果最终\(res < 1e9\),说明\(\geq 2\)的数的个数小于\(m = log(1e9)\)个,直接\(O(m^2)\)暴力枚举选择哪段区间为乘积即可
- 后面的过程模拟即可,注意区间中存在\(1\),模拟时注意细节即可
const int N = 2e5 + 10, M = 4e5 + 10;
int n, a[N], b[N], idx;
void solve()
{
cin >> n;
for (int i = 1; i <= n; ++i)
cin >> a[i];
int l = 1, r = n;
while (a[l] == 1 && l < r)
l++;
while (a[r] == 1 && l < r)
r--;
int res = 1;
for (int i = l; i <= r; ++i)
{
res *= a[i];
if (res > 1e9)
{
cout << l << " " << r << endl;
return;
}
}
idx = 0;
int sum = 0;
for (int i = 1; i <= n; ++i)
{
if (a[i] > 1)
b[++idx] = i;
sum += a[i];
}
int ans = sum, ansl = 1, ansr = 1;
for (int i = 1; i <= idx; ++i)
{
res = 1;
l = b[i];
int s = 0;
for (int j = i; j <= idx; ++j)
{
res *= a[b[j]];
r = b[j];
s += a[b[j]];
int val = sum - s - (r - l + 1 - (j - i + 1)) + res;
if (val > ans)
{
ans = val;
ansl = l, ansr = r;
}
}
}
cout << ansl << " " << ansr << endl;
}
Codeforces Round 895 (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为还需要的蜡烛数, ...
随机推荐
- 全网最适合入门的面向对象编程教程:47 Python函数方法与接口-回调函数Callback
全网最适合入门的面向对象编程教程:47 Python 函数方法与接口-回调函数 Callback 摘要: 回调函数是编程中一种非常常见的模式,用于将函数作为参数传递给其他函数或方法.这种模式在 Pyt ...
- 搭建ipv6并发代理池
声明 本文章中所有内容仅供学习交流,抓包内容.敏感网址.数据接口均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关,若有侵权,请联系我立即删除! 学习目标 ounter(l ...
- DOM & BOM – 用 Canvas 修图
前言 以前有写过一篇关于 canvas 处理图片的文章. 非常乱, 这篇做一个整理. 参考 Stack Overflow – HTML5 Canvas Rotate Image Stack Overf ...
- 记一次 公司.NET项目部署在Linux环境压测时 内存暴涨分析
一:背景 讲故事 公司部署在某碟上的项目在9月份压测50并发时,发现某个容器线程.内存非正常的上涨,导致功能出现了异常无法使用.根据所学,自己分析了下线程和内存问题,分析时可以使用lldb或者wind ...
- mongo 副本集rs 理解和使用小结
转载请注明出处: 在MongoDB中,rs(通常指的是"replica set"的缩写)是复制集(Replica Set)的标识符或在使用时的一种常见前缀,尤其是在命令行工具和脚本 ...
- C++11新初始化方法 使用{}初始化变量
列表初始化 在C++11及以后的版本中,使用{}来初始化变量是一种新的初始化方法,称为列表初始化(List Initialization).这种初始化方法可以用来初始化内置类型.自定义类型以及聚合类型 ...
- 使用ftrace查找Kernel启动阶段的延时原因
查找Kernel启动阶段的延时原因 1.确保内核配置了如下选项 CONFIG_FTRACE: "Tracers" CONFIG_FUNCTION_TRACER: "Ker ...
- iOS关于NSNotificationCenter通知使用小结
常用的页面之间传值方式是参数,单例,通知,委托,以及其他全局变量等等.通知是一种广播形式,可以一对多通知传值.最近在项目中用的模块化开发, 通过封装抽取,将页面分为上中下三个模块.最简单的方式是把所有 ...
- redis 配置文件 - 启动redis 使用文件配置启动
# Redis configuration file example. # # Note that in order to read the configuration file, Redis mus ...
- C# 根据主键ID查询数据库的数据 反射和泛型实现
// 引入命名空间 using Zhu.ADO.NET.DBProxy; using Zhu.ADO.NET.Models.models; Console.WriteLine("====== ...