感染(low)

Description

n户人家住在一条直线上,从左往右依次编号为1,2,...,n。起初,有m户人家感染了COVID-19,而接下来的每天感染的人家都会感染他家左右两家的人,问t天后总共有多少人家会感染。

Input

第一行输入三个整数n(1 <= n <= 2e5),m(0 <= m <= n),t(1<= t <= 2e5)。

第二行m个整数ai(1 <= ai <= n),代表最初感染的m户人家的编号。

Output

输出一个整数,代表最后会有多少人家感染。

Sample Input 1

10 3 2
1 3 4

Sample Output 1

6

分析:这个题实际上就是以m个点为中心,生成了m条长度最多为2*m的线段,然后合并这m条线段就可以了。
第i条线段的信息可以表示为[max(1, a[i] - t), min(n, a[i] + t)}。
代码:
#include<bits/stdc++.h>
using namespace std;
const int maxn = 2e5 + ;
int a[maxn];
vector<pair<int, int> > v;
int main() {
int n, m, t;
cin >> n >> m >> t;
for (int i = ; i <= m; i++)
cin >> a[i];
sort(a + , a + + m);
for (int i = ; i <= m; i++) {
int l = max(, a[i] - t);
int r = min(n, a[i] + t);
v.push_back(make_pair(l, r));
}
int i = , res = ;
while (i < m) {
int j = i + ;
while (j < m && v[j].first <= v[j - ].second) {
j++;
}
res += v[j - ].second - v[i].first + ;
i = j;
}
cout << res <<endl;
return ;
}

第k短路
 

Description

一天,HighLights实在是闲的不行,他选取了n个地点,n各地点之间共有m条路径,他想找到这m条路径组成的第k短路,你能帮助他嘛?

Input

第一行三个正整数,地点的数量n(2 <= n <= 2e5),边的数量m(1 <= m <= 2e5),k(1 <= k <= min(m,  200))。

接下来m行,每行三个整数,边的一个顶点u(1<=u<=n),边的另一个顶点v(1<=v<=n),边的权值w(1<=w<=1e5),代表u有一条到v权值为w的单向边。

Output

输出第k短路的权值。

Sample Input 1

4 4 3
1 3 27
1 4 16
1 2 15
2 4 3

Sample Output 1

16

分析:这个题可以刚开始看的时候被吓到了,但是实际上这个题比较简单。因为k被限制了,k比较小,保证了k不大于m。
也就是第k短路是由权值前k小的边产生的子图构成的。
那么我们就可以对边进行权值从小到大排序,然后取权值前k的边,重新建图。
这里对顶点需要进行重新编号,可以使用map或set,然后建立一个新的单向图。
再对这个图跑个floyd,最后把G[i][j](i != j)都取出来,
从小到大排个序,那么排序完后第k个就是我们想要的第k短路了。
代码:
#include<bits/stdc++.h>
using namespace std;
const int maxn = 4e5 + ;
const int maxm = 4e2 + ;
struct node{
int u, v, w;
} e[maxn];
bool cmp(node a, node b) {
return a.w < b.w;
}
set<int> st;
int G[maxm][maxm];
map<int, int> id;
vector<int> res;
int main() { int n, m, t;
memset(G, 0x3f, sizeof(G));
for (int i = ; i < maxm; i++) {
G[i][i] = ;
}
cin >> n >> m >> t;
for (int i = ; i < m; i++) {
cin >> e[i].u >> e[i].v >> e[i].w;
}
sort(e, e + m, cmp);
for (int i = ; i < t; i++) {
st.insert(e[i].u);
st.insert(e[i].v);
}
int len = ;
for (auto p = st.begin(); p != st.end(); p++) {
id[*p] = ++len;
}
for (int i = ; i < t; i++) {
G[id[e[i].u]][id[e[i].v]] = min(G[id[e[i].u]][id[e[i].v]], e[i].w);
}
for (int i = ; i <= len; i++) {
for (int j = ; j <= len; j++) {
for (int k = ; k <= len; k++) {
G[i][j] = min(G[i][j], G[i][k] + G[k][j]);
}
}
}
for (int i = ; i <= len; i++) {
for (int j = ; j <= len; j++) {
if (i == j) continue;
res.push_back(G[i][j]);
}
}
sort(res.begin(), res.end());
cout << res[t - ] << endl;
return ;
}

2020 NUC 19级第一次训练赛的更多相关文章

  1. Xeon 第一次训练赛 苏州大学ICPC集训队新生赛第二场(同步赛) [Cloned]

    A.给出一个字符串,求出连续的权值递增和,断开以后权值重新计数,水题 #include<iostream> #include<string> #include<cmath ...

  2. 2018.10.19浪在ACM 集训队第一次测试赛

    2018.10.19浪在ACM 集训队第一次测试赛 待参考资料: [1]:https://blog.csdn.net/XLno_name/article/details/78559973?utm_so ...

  3. 2018省赛赛第一次训练题解和ac代码

    第一次就去拉了点思维很神奇的CF题目 2018省赛赛第一次训练 # Origin Title     A CodeForces 607A Chain Reaction     B CodeForces ...

  4. 2018天梯赛第一次训练题解和ac代码

    随着评讲的进行代码和题解会逐步放上来 2018天梯赛第一次训练 1001 : 进制转换 Time Limit(Common/Java):1000MS/10000MS     Memory Limit: ...

  5. 10.0.0.55_12-16训练赛部分writeup

    0x1 - MISC MISC100 一张帅行的照片 目测是图片隐写,但是binwalk并没有出来,应该是对文件头进行了修改 010editor查看一下,发现在jpg文件尾之后还有大量的数据 而且在灰 ...

  6. Contest1592 - 2018-2019赛季多校联合新生训练赛第二场(部分题解)

    Contest1592 - 2018-2019赛季多校联合新生训练赛第二场 D 10248 修建高楼(模拟优化) H 10252 组装玩具(贪心+二分) D 传送门 题干 题目描述 C 市有一条东西走 ...

  7. Contest1585 - 2018-2019赛季多校联合新生训练赛第一场(部分题解)

    Contest1585 - 2018-2019赛季多校联合新生训练赛第一场 C 10187 查找特定的合数 D 10188 传话游戏 H 10192 扫雷游戏 C 传送门 题干: 题目描述 自然数中除 ...

  8. 7.30 正睿暑期集训营 A班训练赛

    目录 2018.7.30 正睿暑期集训营 A班训练赛 T1 A.蔡老板分果子(Hash) T2 B.蔡老板送外卖(并查集 最小生成树) T3 C.蔡老板学数学(DP NTT) 考试代码 T2 T3 2 ...

  9. 复旦高等代数I(19级)每周一题

    本学期的高等代数每周一题活动计划从第2教学周开始,到第15教学周结束,每周的周末公布一道思考题(共14道,思考题一般与下周授课内容密切相关),供大家思考和解答.每周一题将通过“高等代数官方博客”(以博 ...

随机推荐

  1. Fluent_Python_Part2数据结构,02-array-seq,序列类型

    1. 序列数据 例如字符串.列表.字节序列.元组.XML元素.数据库查询结果等,在Python中用统一的风格去处理.例如,迭代.切片.排序.拼接等. 2. 容器序列与扁平序列 容器序列:容器对象包含任 ...

  2. Windows配置本地Hadoop运行环境

    很多人喜欢用Windows本地开发Hadoop程序,这里是一个在Windows下配置Hadoop的教程. 首先去官网下载hadoop,这里需要下载一个工具winutils,这个工具是编译hadoop用 ...

  3. Linux - 命令 - top命令

    负载检查:https://blog.csdn.net/HANLIPENGHANLIPENG/article/details/79172053 参考:https://blog.csdn.net/gxia ...

  4. 【代码学习】PYTHON字典(Dictionary)

    一.什么是字典 字典是另一种可变容器模型,且可存储任意类型对象. 字典的每个键值(key->value)对用(:)分割,每个对之间用逗号(,)分割,整个字典包括在花括号({})中,格式如下 d ...

  5. component:(resolve) => require

    resolve => require(['../pages/home.vue'], resolve)这种写法是异步模块获取,打包的时候每次访问这个路由的时候会单调单个文件,按需加载,不过这种写法 ...

  6. java编译问题之Description Resource Path Location Type Java compiler level does not match the version of

    project 编译问题,需要三处的jdk版本要保持一致,才能编译通过. 1.在项目上右键properties->project Facets->修改右侧的version  保持一致 2. ...

  7. linux文件或目录属性

    wc(word count)命令的功能:统计指定文件的字节数.字数.行数.,并将统计结果显示输出 命令参数: -c 只显示字节数 -l    只显示行数 -w 只显示字数 od命令:查看二进制文件信息 ...

  8. netty集成springboot

    一 前言 springboot 如何集成netty实现mapper调用不为null的问题让好多读者都头疼过,知识追寻者发了一点时间做了个基本入门集成应用给读者们指明条正确的集成方式,我相信,只要你有n ...

  9. 一个简单的PHP文件下载方法 download

    <?php /* * *@param function downloadFile 文件下载 * *@param string $filename 下载文件的路径(根目录下的绝对路径) * *@p ...

  10. Python3.5学习之旅——day1

    本节内容: 1.Python介绍 2.Hello World程序 3.变量\字符编码 4.用户输入 5.if-else语句 6.循环语句 一.Python介绍 Python是一种动态解释性的强类型定义 ...