A. Extreme Subtraction

把这个数组差分一下,发现操作一的作用是把 \(d_1\) 的大小分给 \(d_i\),而操作二的作用是把 \(d_i\) 减去任意值,目标是把 \(d\) 的值都变为 \(0\)。对于 \(d\) 中大于 \(0\) 的值,就直接用操作二就行了;对于小于 \(0\) 的值,那它只能用 \(d_1\) 补偿;所以就比较一下 \(b_1\) 和 \(- \sum\limits_{i=2}^n[b_i<0]\times b_i\)的大小就行了。

B. Identify the Operations

遍历 \(b\),找到 \(b_i\) 在 \(a\) 中的位置,那么只能删除它左边的那个或右边的那个;但假如左边那个是将来的 \(b\) 的话,那就不能删了;同时会发现,删左边和删右边对序列的影响都是一样的,都是从两个能删的数变成两个能删的数。那就很简单了。

fin >> n >> m;
int mn = 1e9 + 1e2, mx = -1e9 - 1e2, ans = 1;
for (int i = 1; i <= n; i++) fin >> a[i];
for (int i = 1; i <= m; i++) fin >> b[i];
for (int i = 1; i <= n; i++) pnt[a[i]] = i;
for (int i = 1; i <= n; i++) vis[i] = 0;
for (int i = 1; i <= m; i++) vis[pnt[b[i]]] = true;
vis[0] = vis[n + 1] = true;
for (int i = 1; i <= m; i++)
{
(ans *= 2 - vis[pnt[b[i]] - 1] - vis[pnt[b[i]] + 1]) %= mod;
vis[pnt[b[i]]] = false;
}
fout << ans << Endl;

C. Graph Transpositions

惯例分层图。但是分层图的深度特别大怎么办?我们发现,\(2^{18}\) 次方就已经大于 \(n\) 了,所以暂且只建这么 \(18\) 层。

如果这 \(18\) 能到,那就 OK 了。如果不能,那就有讲究了。我们发现这时我们的第一追求是层数少,然后才是这层内的距离近。所以我们可以一层一层拓展,就可以保证层数少。

这么做还是 \(O(n^2)\)的,还需要加上一个剪枝——若当前点在以前的层中已经访问,那就不用再走它,于是复杂度就对了。还有就是 \(18\) 层以后的图上,存的 \(dis\) 就不用包括 \(2^k\) 次方了,就可以处理需要取模的最小值了。

D. Sum

神奇结论题:最多只有一列选了一部分,其他列要么全选要么不选。证明使用反证法就行了。这样问题就从多重背包变成了扣点一个点的 0/1 背包。这个问题可以使用分治或分块处理。

inline update(vector<u64>& f, int sze, u64 val) {
for (int i = k - sze; i >= 0; i--) {
f[i + sze] = max_(f[i + sze], f[i] + val);
}
} u64 ans; void solve(int l, int r, vector<u64> f)
{
if (l == r) {
for (int i = 0; i <= min_(k, m[l]); i++) {
ans = max_(ans, f[k - i] + a[l][i]);
}
return;
}
int mid = (l + r) >> 1; vector<u64> fl = f, fr = f;
for (int i = l; i <= mid; i++) update(fr, m[i], a[i][m[i]]);
for (int i = r; i > mid; i--) update(fl, m[i], a[i][m[i]]);
solve(l, mid, fl); solve(mid + 1, r, fr);
}

Codeforces Round #681 (Div. 1) Solution的更多相关文章

  1. Codeforces Round #466 (Div. 2) Solution

    从这里开始 题目列表 小结 Problem A Points on the line Problem B Our Tanya is Crying Out Loud Problem C Phone Nu ...

  2. 老年OIer的Python实践记—— Codeforces Round #555 (Div. 3) solution

    对没错下面的代码全部是python 3(除了E的那个multiset) 题目链接:https://codeforces.com/contest/1157 A. Reachable Numbers 按位 ...

  3. Codeforces Round #545 (Div. 1) Solution

    人生第一场Div. 1 结果因为想D想太久不晓得Floyd判环法.C不会拆点.E想了个奇奇怪怪的set+堆+一堆乱七八糟的标记的贼难写的做法滚粗了qwq靠手速上分qwqqq A. Skyscraper ...

  4. Codeforces Round 500 (Div 2) Solution

    从这里开始 题目地址 瞎扯 Problem A Piles With Stones Problem B And Problem C Photo of The Sky Problem D Chemica ...

  5. Codeforces Round #607 (Div. 1) Solution

    从这里开始 比赛目录 我又不太会 div 1 A? 我菜爆了... Problem A Cut and Paste 暴力模拟一下. Code #include <bits/stdc++.h> ...

  6. Codeforces Round #578 (Div. 2) Solution

    Problem A Hotelier 直接模拟即可~~ 复杂度是$O(10 \times n)$ # include<bits/stdc++.h> using namespace std; ...

  7. Codeforces Round #681 (Div. 2, based on VK Cup 2019-2020 - Final)【ABCDF】

    比赛链接:https://codeforces.com/contest/1443 A. Kids Seating 题意 构造一个大小为 \(n\) 的数组使得任意两个数既不互质也不相互整除,要求所有数 ...

  8. Codeforces Round #525 (Div. 2) Solution

    A. Ehab and another construction problem Water. #include <bits/stdc++.h> using namespace std; ...

  9. Codeforces Round #520 (Div. 2) Solution

    A. A Prank Solved. 题意: 给出一串数字,每个数字的范围是$[1, 1000]$,并且这个序列是递增的,求最多擦除掉多少个数字,使得别人一看就知道缺的数字是什么. 思路: 显然,如果 ...

随机推荐

  1. Less-(26~28) preg_replace3

    Less-26: 核心语句:  各种回显均存在. 本题相比Less-25,多屏蔽了很多符号: 首先是各种注释符 --+,#,/**/  . /[]/表示字符集合:任何出现在里面的字符均会被替换. 屏蔽 ...

  2. Dapr-服务调用

    前言 上一篇对Dapr进行了了解,并搭建了Dapr环境.接下来就对Dapr的各个构建块类型的了解.应用实际案例. 一.服务调用: 在许多具有多个需要相互通信的服务的环境中,都会面临着很多问题. 如: ...

  3. abstract使用方式

    springMVC中的 LocalContextHolder是一个 abstract类.里边方法都是static 的. 不能被继承.不能实例化.只能调用其定义的static 方法.这种 abstrac ...

  4. [对对子队]会议记录5.25(Scrum Meeting11)

    今天已完成的工作 吴桐雨 ​ 工作内容:设计第10.11关 ​ 相关issue:设计额外关卡 ​ 相关签入:level10 level11 吴昭邦 ​ 工作内容:写测试代码 ​ 相关issue:测试初 ...

  5. websocket入门案例(echo)

    websocket是用来干什么的,具体的请自行百度. 本文实现一个简单的websocket的入门小例子,实现客户端发送一句换,服务器端返回.即一个简单的交互. 一.服务器端的实现 1.创建一个类实现S ...

  6. docker run 的基本用法

    docker run 命令用来创建并启动一个容器 语法:docker run [options] image [command] [args-] 示例:docker run -dit -v 别名:容器 ...

  7. python redis自带门神 lock 方法

    redis 支持的数据结构比较丰富,自制一个锁也很方便,所以极少提到其原生锁的方法.但是在单机版redis的使用时,自带锁的使用还是非常方便的.自己有车还打啥滴滴顺风车是吧,本篇主要介绍redis-p ...

  8. 剖析虚幻渲染体系(12)- 移动端专题Part 1(UE移动端渲染分析)

    目录 12.1 本篇概述 12.1.1 移动设备的特点 12.2 UE移动端渲染特性 12.2.1 Feature Level 12.2.2 Deferred Shading 12.2.3 Groun ...

  9. Qt5 项目程序打包发布 详细教程

    概述 当我们用QT写好了一个软件,要把你的程序分享出去的时候,不可能把编译的目录拷贝给别人去运行.编译好的程序应该是一个主程序,加一些资源文件,再加一些动态链接库,高大上一些的还可以做一个安装文件. ...

  10. JMeter学习笔记--录制脚本(二)

    第一步:在JMeter中添加线程组,命名为访问首页 第二步:在线程组下添加HTTP请求默认值 添加->配置元件->HTTP请求默认值,设置服务器IP和端口号(JMeter默认使用80端口号 ...