2019/10/17 CSP模拟 总结
T1 补票 Ticket
没什么好说的,不讲了
T2 删数字 Number
很后悔的是其实考场上不仅想出了正解的方程,甚至连优化都想到了,却因为码力不足只打了\(O(n^2)\)暴力,甚至还因为细节挂成了\(40\ pts\)
以后还是应该多写一下码农题
规定一下,下面的\(j\)没有特殊说明,取值范围默认在\(1, i - 1\)
考虑什么情况是合法的,首先最后对答案有贡献的元素组成的序列一定是严格上升的,即\(a_i > a_j\)
然后考虑还有没有别的限制呢
放一个图

看到我们的对答案有贡献的序列和其对应的坐标的连边一定是一个越来越倾斜(并且逆时针旋转)的过程,思考一下为什么,发现如果不满足前面那个条件的话实际上是没法通过题目的变换方法得到最终对应的序列
举个例子
1 2 3 5 2
其中的3和5并不能同时对答案作出贡献
所以又有了一个限制条件\(i - a[i] > = j - a[j]\)
看一下两个条件$$a_i > a_j$$ $$i - a[i] > = j - a[j]$$
发现是一个二维偏序
考虑一维一维的处理,先按第一个条件排一下序,然后在排序后的序列上处理后面那个条件,树状数组维护一下
#include<bits/stdc++.h>
#define N (100000 + 10)
#define lowbit(x) (x & (-x))
using namespace std;
inline int read() {
int cnt = 0, f = 1; char c = getchar();
while (!isdigit(c)) {if (c == '-') f = -f; c = getchar();}
while (isdigit(c)) {cnt = (cnt << 3) + (cnt << 1) + (c ^ 48); c = getchar();}
return cnt * f;
}
int n, tot, w, ans, gmax, BIT[N];
void modify(int x, int g) {
for (; x <= gmax; x += lowbit(x)) BIT[x] = max(BIT[x], g);
}
int query(int x) {
int ans = 0;
for (; x; x -= lowbit(x)) ans = max(ans, BIT[x]);
return ans;
}
struct node {
int d, s; //d: i - a[i].s, s: from input
}a[N];
bool cmp(node a, node b) {
return a.d == b.d ? a.s < b.s : a.d < b.d;
}
int main() {
n = read();
for (register int i = 1; i <= n; ++i) {
w = read();
if (w > i) continue;
a[++tot].s = w, a[tot].d = i - w;
gmax = max(gmax, w);
}
sort (a + 1, a + tot + 1, cmp);
for (register int i = 1; i <= tot; ++i) {
int d = query(a[i].s - 1) + 1;
modify(a[i].s, d);
ans = max(ans, d);
} printf("%d\n", ans);
return 0;
}
T3 滑冰 Shortest
感觉题解很好理解,但就是想不到
先说一下算法流程
分别按\(x\)排一个序,\(y\)排一个序,然后相邻的连上边,跑最短路即可
说一下为什么是正确的
首先\(min(|x[i] - x[j]|, |y[i] - y[j]|)\)这个条件是完全不用考虑的,因为最短路本身就是找\(min\)的过程,就算两条边都连上也可以得到正确答案
考虑\(O(n^2)\)暴力,即每个点往其他所有点连边,然后这样显然跑不动
怎么优化呢
上面那个算法很巧妙的一点是,因为我们排过序了,所以两个点之间的连边一定已经是不可以分拆的最小单位了,并且用这些最小单位边一定可以组成其他的边,相当于去除了暴力连边中的重复信息,于是复杂度优化为\(O(nlog(n))\)
#include<bits/stdc++.h>
#define N (1001000 + 10)
using namespace std;
inline int read() {
int cnt = 0, f = 1; char c = getchar();
while (!isdigit(c)) {if (c == '-') f = -f; c = getchar();}
while (isdigit(c)) {cnt = (cnt << 3) + (cnt << 1) + (c ^ 48); c = getchar();}
return cnt * f;
}
int n, z;
struct node {
int x, y;
int pos;
}a[N];
bool cmp(node a, node b) {
return a.x == b.x ? a.y < b.y : a.x < b.x;
}
bool cmp2(node a, node b) {
return a.y == b.y ? a.x < b.x : a.y < b.y;
}
int first[N], nxt[N << 1], to[N << 1], w[N << 1], tot;
long long d[N];
bool vis[N];
void add(int x, int y, int z) {nxt[++tot] = first[x], first[x] = tot, to[tot] = y, w[tot] = z;}
priority_queue < pair<int, int> > q;
void dijkstra() {
memset(d, 0x3f, sizeof d);
memset(vis, 0, sizeof vis);
d[1] = 0;
q.push(make_pair(-d[1], 1));
while (!q.empty()) {
int x = q.top().second; q.pop();
if (vis[x]) continue;
vis[x] = 1;
for (register int i = first[x]; i; i = nxt[i]) {
int v = to[i], z = w[i];
if (d[v] > d[x] + z) {
d[v] = d[x] + z;
q.push(make_pair(-d[v], v));
}
}
}
}
int main() {
// freopen("shortest.in", "r", stdin);
// freopen("shortest.out", "w", stdout);
n = read();
for (register int i = 1; i <= n; ++i) a[i].x = read(), a[i].y = read(), a[i].pos = i;
sort (a + 1, a + n + 1, cmp);
for (register int i = 1; i < n; ++i) {
int z = a[i + 1].x - a[i].x;
add(a[i].pos, a[i + 1].pos, z), add(a[i + 1].pos, a[i].pos, z);
}
sort (a + 1, a + n + 1, cmp2);
for (register int i = 1; i < n; ++i) {
int z = a[i + 1].y - a[i].y;
// cout<<z<<endl;
add(a[i].pos, a[i + 1].pos, z), add(a[i + 1].pos, a[i].pos, z);
}
dijkstra();
printf("%lld", d[n]);
return 0;
}
2019/10/17 CSP模拟 总结的更多相关文章
- 10.17 NOIP模拟赛
目录 2018.10.17 NOIP模拟赛 A 咒语curse B 神光light(二分 DP) C 迷宫maze(次短路) 考试代码 B 2018.10.17 NOIP模拟赛 时间:1h15min( ...
- 【2019.10.17】十天Web前端程序员体验(软件工程实践第五次作业)
结对信息.具体分工 Github地址:https://github.com/MokouTyan/131700101-031702425 学号 昵称 主要负责内容 博客地址 131700101 莫多 代 ...
- 2019.10.26 CSP%您赛第三场
\(CSP\)凉心模拟^_^ --题源\(lqx.lhc\)等各位蒟蒻 题目名称 比赛 传递消息 开关灯 源文件名 \(competition.cpp\) \(message.cpp\) \(ligh ...
- 2019.10.15 CSP初赛知识点整理
初赛需要的知识点整理如下: (1)计算机的硬件组成与基本常识 (2)单位/进制的转换 (3)进制/逻辑运算相关 (4)概率与期望 (5)排序的各种性质 (6)简单数据结构的使用(栈.队列.链表等) ( ...
- 2019.10.29 CSP%您赛第四场t2
我太菜了我竟然不会分层图最短路 ____________________________________________________________________________________ ...
- 2019.10.24 CSP%你赛第二场d1t3
题目描述 Description 精灵心目中亘古永恒的能量核心崩溃的那一刻,Bzeroth 大陆的每个精灵都明白,他们的家园已经到了最后的时刻.就在这危难关头,诸神天降神谕,传下最终兵器——潘少拉魔盒 ...
- 2019.10.28 CSP%您赛第四场t3
我写不动前两个了. 原谅一下. ____________________________________________________________________________________ ...
- 【2019.10.7 CCF-CSP-2019模拟赛 T3】未知的数组(unknown)(并查集+动态规划)
预处理 考虑模数\(10\)是合数不好做,所以我们可以用一个常用套路: \(\prod_{i=l}^ra_i\equiv x(mod\ 10)\)的方案数等于\(\prod_{i=l}^ra_i\eq ...
- 【2019.10.7 CCF-CSP-2019模拟赛 T2】绝对值(abs)(线段树细节题)
找规律 设\(p_i=a_{i+1}-a_i\),则答案就是\(\sum_{i=1}^{n-1}p_i\). 考虑若将\(a_i\)加上\(x\)(边界情况特殊考虑),就相当于是将\(p_{i-1}\ ...
随机推荐
- iOS 7.1的Safari为meta标签新增minimal-ui属性,在网页加载时隐藏地址栏与导航栏
在 iOS 7.1 的 Safari 中为 meta 标签新增 minimal-ui 属性,让网页在加载时便可隐藏顶部的地址栏与底部的导航栏. 如何实现?你只需将“minimal-ui”加入 view ...
- java-day12
数据结构 常用的数据存储结构:栈,队列,数组,列表,红黑树. 栈:先进后出(入口和出口在用一侧) 队列:先进先出 数组: 查询快:因为数组的地址是连续的,通过数组的首地址找到数组中的元素. 增/删慢: ...
- 《转》python(7)列表
转自 http://www.cnblogs.com/BeginMan/p/3153842.html 一.序列类型操作符 1.切片[]和[:] 2.成员关系操作符(in ,not in ) 1: s1 ...
- POJ Evacuation /// 二分图最大匹配
题目大意: 在一个n*m的房间中 ‘X’为墙 ‘D’为门 ‘.’为人 门只存在与外围 人每秒钟只能向四连通区域走一步 门比较狭窄 每秒钟只能通过一个人 求所有人逃脱的最短时间 如果不可能则输出impo ...
- Js_案例(电灯)
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- JAVA读取PROPERTIES文件方式一
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.i ...
- 结对编程收获-Core10组-PB16110698
本周结对编程追加作业:记录收获.坦白说,我的收获多而杂,一时不知从何说起,以下试图从各方面简要谈谈. 一.编程能力收获 从编程能力方面,我收获的主要是类的设计思路和算法设计.在作业要求blog的指引下 ...
- Android开发 QRCode二维码开发第三方框架
前言 Android开发里二维码开发经常用到,这里简单的介绍下Android开发里的二维码. 最广泛使用的二维码库zxing zxing是最广泛的二维码库各个平台都可以适用它,但是Android平台使 ...
- bzoj2322 梦想封印
题意和题解见思路索引. 标程及易错点: #include<bits/stdc++.h> using namespace std; typedef long long ll; ll read ...
- Flink on YARN(下):常见问题与排查思路
Flink 支持 Standalone 独立部署和 YARN.Kubernetes.Mesos 等集群部署模式,其中 YARN 集群部署模式在国内的应用越来越广泛.Flink 社区将推出 Flink ...