nowcoder-548C-Tachibana Kanade Loves Review
链接:https://ac.nowcoder.com/acm/contest/548/C
来源:牛客网
空间限制:C/C++ 524288K,其他语言1048576K
64bit IO Format: %lld
题目描述
最近,实力强大的 QingyuQingyu 当选了 IODS 9102 的出题人。众所周知, IODS 是一场极其毒瘤的比赛。为了在这次比赛中取得好的成绩,立华奏决定学习可能考到的每一个知识点。
在 QingyuQingyu 的博客中,立华奏得知这场比赛总共会考察选手 n 个知识点。此前,立华奏已经依靠自学学习了其中 k 个知识点。接下来,立华奏需要学习其他的知识点,每学习一个单独的知识点,需要消耗的时间为 TiTi 天。同时,某些知识点之间存在联系,可以加速学习的过程。经过计算,立华奏一共发现了其中 m 种联系,第 i 种联系可以表示为(Xi,Yi,Hi)(Xi,Yi,Hi),其含义为“在掌握了第 XiXi 个知识点和第 YiYi 个知识点中任意一个后,学习 HiHi 天即可掌握另一个知识点”。
留给立华奏的时间所剩无几,只有 t 天,因此,她想知道自己能不能在这 t 天内学习完成所有的知识点。
输入描述:
本题输入量较大,请注意使用效率较高的读入方式
输入的第一行包含四个整数 n, m, k, t,含义见上所述。
接下来一行,包含 k 个整数,表示立华奏已经学习过的知识点。如果 k=0,则此处为一空行。
接下来 m 行,每行 3 个整数 Xi,Yi,HiXi,Yi,Hi,描述一种联系。
输出描述:
如果立华奏能够学习完所有的知识点,输出一行 Yes。否则输出 No
备注:
0⩽k⩽n⩽106,m⩽5×106,t⩽1018,Ti,Hi⩽103
思路:
这就是一个最小生成树,只不过这题卡常数,因此从这题也学到了不少东西;
- 比赛时自己敲的
C 运行超时 2001 0 1293 C++ #include "bits/stdc++.h"
using namespace std;
typedef pair<int, int> PII;
typedef long long LL;
const int MAXN = 1e6 + ;
priority_queue<PII, vector<PII>, greater<PII> > que;
vector<PII> vp[MAXN];
vector<int> vi;
bool ok[MAXN];
void add(int k) {
for (int i = ; i < vp[k].size(); i++) {
que.push(vp[k][i]);
}
vp[k].clear();
}
int main() {
int n, m, k, s;
int a, b, c, cnt = ;
LL t, sum = ;
scanf("%d%d%d%lld", &n, &m, &k, &t);
for (int i = ; i <= n; i++) {
scanf("%d", &s);
que.push({s, i});
}
for (int i = ; i <= k; i++) {
scanf("%d", &s);
vi.push_back(s);
}
for (int i = ; i <= m; i++) {
scanf("%d%d%d", &a, &b, &c);
vp[a].push_back({c, b});
vp[b].push_back({c, a});
}
for (int i = ; i < vi.size(); i++) {
int j = vi[i];
if (ok[j] == false) {
ok[j] = true;
cnt++;
add(j);
}
}
while (cnt != n) {
PII j = que.top();
que.pop();
if (ok[j.second] == false) {
ok[j.second] = true;
cnt++;
sum += j.first;
add(j.second);
}
}
if (sum <= t) {
puts("Yes");
} else {
puts("No");
}
return ;
}类似Prim算法每次取最短边,但是比赛的时候我连这是最小生成树都没看出来,所以用了一个优先队列来维护目前能连起来的边,如果边的两个端点都未联通,则这条边在vector里不会加入优先队列,vector和优先队列转移耗费大量时间。而且各种耗时
- 看了题解之后又经过多次修改的代码(题解链接:https://ac.nowcoder.com/discuss/173818)
C 答案正确 1111 69944 1813 C++ #include "bits/stdc++.h"
using namespace std;
typedef long long LL;
typedef pair<int, int> PII;
const int MAXN = 1e6 + ;
const int MAXW = ;
vector<PII> vec[MAXW + ];
int pre[MAXN], rak[MAXN];
int n, m, k;
int u, v, w;
LL t;
inline LL read() {
char c = getchar();
LL num = ;
while (!isdigit(c)) {
c = getchar();
}
while (isdigit(c)) {
num = num * + (c ^ '');
c = getchar();
}
return num;
}
int find(int n) {
if (pre[n] == -) {
return n;
}
return pre[n] = find(pre[n]);
}
bool check(int k) {
for (w = ; true; w++) {
for (int i = ; i < vec[w].size(); i++) {
PII p = vec[w][i];
u = find(p.first);
v = find(p.second);
if (u != v) {
t -= w;
if (t < ) {
return false;
}
k++;
if (t >= (n - k) * 1LL * MAXW) {
return true;
}
if (rak[u] > rak[v]) {
pre[v] = u;
} else {
pre[u] = v;
if (rak[u] == rak[v]) {
rak[v]++;
}
}
}
}
}
}
int main() {
n = read(), m = read(), k = read(), t = read();;
memset(pre, -, sizeof(pre));
memset(rak, , sizeof(rak));
for (int i = ; i <= n; i++) {
w = read();
vec[w].push_back({, i});
}
for (int i = ; i <= k; i++) {
u = read();
pre[u] = ;
}
for (int i = ; i <= m; i++) {
u = read();
v = read();
w = read();
vec[w].push_back({u, v});
}
if (check(k)) {
puts("Yes");
} else {
puts("No");
}
return ;
}在此之前就看到过快读(read),只是之前没有遇到像这题一样卡输入的。这题除非其他地方优化到极致,否则不用快读过不去。还有就是学到了并查集的启发式合并,之前写的并查集都只用了路径压缩来优化,才发现还可以用启发式合并来优化,而且就这题看来,用了启发式合并之后快了不少。还有就是学到了inline,之前没怎么用过这个关键字,网上查了一下说是可以提高代码效率(类似宏定义),不过关于这个inline,我试过去掉inline提交反而快了,不知道为什么。
链接:https://ac.nowcoder.com/acm/contest/548/C
来源:牛客网
空间限制:C/C++ 524288K,其他语言1048576K
64bit IO Format: %lld
题目描述
最近,实力强大的 QingyuQingyu 当选了 IODS 9102 的出题人。众所周知, IODS 是一场极其毒瘤的比赛。为了在这次比赛中取得好的成绩,立华奏决定学习可能考到的每一个知识点。
在 QingyuQingyu 的博客中,立华奏得知这场比赛总共会考察选手 n 个知识点。此前,立华奏已经依靠自学学习了其中 k 个知识点。接下来,立华奏需要学习其他的知识点,每学习一个单独的知识点,需要消耗的时间为 TiTi 天。同时,某些知识点之间存在联系,可以加速学习的过程。经过计算,立华奏一共发现了其中 m 种联系,第 i 种联系可以表示为(Xi,Yi,Hi)(Xi,Yi,Hi),其含义为“在掌握了第 XiXi 个知识点和第 YiYi 个知识点中任意一个后,学习 HiHi 天即可掌握另一个知识点”。
留给立华奏的时间所剩无几,只有 t 天,因此,她想知道自己能不能在这 t 天内学习完成所有的知识点。
输入描述:
本题输入量较大,请注意使用效率较高的读入方式
输入的第一行包含四个整数 n, m, k, t,含义见上所述。
接下来一行,包含 k 个整数,表示立华奏已经学习过的知识点。如果 k=0,则此处为一空行。
接下来 m 行,每行 3 个整数 Xi,Yi,HiXi,Yi,Hi,描述一种联系。
输出描述:
如果立华奏能够学习完所有的知识点,输出一行 Yes。否则输出 No
备注:
0⩽k⩽n⩽106,m⩽5×106,t⩽1018,Ti,Hi⩽103
nowcoder-548C-Tachibana Kanade Loves Review的更多相关文章
- 牛客练习赛43 Tachibana Kanade Loves Review C(最小生成树Kruskal)
链接:https://ac.nowcoder.com/acm/contest/548/C来源:牛客网 题目描述 立华奏是一个刚刚开始学习 OI 的萌新. 最近,实力强大的 QingyuQingyu 当 ...
- 牛客练习赛43C Tachibana Kanade Loves Review
题目地址 Link 题解 虚点这种东西还是没有掌握好啊. 考虑建一个虚点,向已经学会的东西连一条边权为0的边,关系正常连边,单独学的从虚点连一条边过去. 然后做一遍最小生成树就得到答案了. 这题略卡常 ...
- 牛客网 牛客练习赛43 C.Tachibana Kanade Loves Review-最小生成树(并查集+Kruskal)+建虚点+读入挂
链接:https://ac.nowcoder.com/acm/contest/548/C来源:牛客网 Tachibana Kanade Loves Review 时间限制:C/C++ 2秒,其他语言4 ...
- 牛客网 牛客练习赛43 F.Tachibana Kanade Loves Game-容斥(二进制枚举)+读入挂
链接:https://ac.nowcoder.com/acm/contest/548/F来源:牛客网 Tachibana Kanade Loves Game 时间限制:C/C++ 1秒,其他语言2秒 ...
- 牛客网 牛客练习赛43 B.Tachibana Kanade Loves Probability-快速幂加速
链接:https://ac.nowcoder.com/acm/contest/548/B来源:牛客网 Tachibana Kanade Loves Probability 时间限制:C/C++ 1秒, ...
- 牛客练习赛43 Tachibana Kanade Loves Game (简单容斥)
链接:https://ac.nowcoder.com/acm/contest/548/F来源:牛客网 题目描述 立华奏是一个天天打比赛的萌新. 省选将至,萌新立华奏深知自己没有希望进入省队,因此开始颓 ...
- 牛客练习赛43 Tachibana Kanade Loves Probability(快速幂)
链接:https://ac.nowcoder.com/acm/contest/548/B来源:牛客网 题目描述 立华奏在学习初中数学的时候遇到了这样一道大水题: “设箱子内有 n 个球,其中给 m 个 ...
- 牛客练习赛43D Tachibana Kanade Loves Sequence
题目链接:https://ac.nowcoder.com/acm/contest/548/D 题目大意 略 分析 贪心,首先小于等于 1 的数肯定不会被选到,因为选择一个数的代价是 1,必须选择大于1 ...
- 牛客练习赛43B Tachibana Kanade Loves Probability
题目链接:https://ac.nowcoder.com/acm/contest/548/C 题目大意 略 分析 利用快速幂先移到 k1 位,然后开始一个一个取余数. 代码如下 #include &l ...
随机推荐
- SQL 2005 带自增列 带外键约束 数据导入导出
1,生成建表脚本 选中要导的表,点右键-编写表脚本为-create到 ,生成建表脚本 2,建表(在新库),但不建外键关系 不要选中生成外键的那部分代码,只选择建表的代码 3,导数据,用SQL STU ...
- jq监控滑动
$(window).scroll(function () { if ($(window).scrollTop() == $(document).height() - $(window).height( ...
- -bash: fultter: command not found
flutter build apk bash: flutter: command not found 在studio中的控制台出现上面错误(如图所示) 解决办法: 安装flutter时,安装时可以执行 ...
- protobuf编译工具使用
1.下载,配置环境变量 下载地址:https://github.com/google/protobuf/releases,选择protoc-xxx-win64.zip下载 把.exe文件的位置加入到P ...
- java 利用管道实现线程间通信
package com.lb; import java.io.IOException;import java.io.PipedInputStream;import java.io.PipedOutpu ...
- 图论模型--dijstra算法和floyd算法
matlab代码实现:https://blog.csdn.net/weixin_40108753/article/details/81237585 python代码实现:
- 批量刷数据sql
update t_free_m** m set m.plate_no = ( select v.plate_num from t_wh_vehi*** v where v.vin = m.car_v ...
- docker 一些简略环境搭建及部分链接
1.center 7 搭建 docker https://www.cnblogs.com/yufeng218/p/8370670.html 2.docker 命令 https://www.cnblo ...
- 如何把word文档导入到数据库中——java POI
本文方法借鉴于https://www.cnblogs.com/ljysy/p/10574197.html 在经过朋友的指导下,在处理文档的方式上有所不同. 我的数据库使用的是SQL server,这篇 ...
- 主流CAD菜单开发
AutoCAD Inventor Solidedge Proe UGNX