「2018-12-02模拟赛」T1 最短路 解题报告
1.最短路(short.pas/cpp/in/out)
问题描述:
小 C 终于被小 X 感动了,于是决定与他看电影,然而小 X 距离电影院非常远,现在假设
每条道路需要花费小 X 的时间为 1,由于有数以万计的好朋友沿路祝贺,导致小 X 在通过某
些路不得不耗费 1 的时间来和他们聊天,尽管他希望尽早见到小 C,所以他希望找到一条最
快时间到达电影院的路。
一开始小 X 在 1 号点,共有 N 个点,M 条路,电影院为 T 号点。
输入:
第一行 3 个正整数,分别为 n,m 和 t。
以下 m 行,每行 3 个数,表示连接的编号以及权值。
(注意,可能会有重边)
输出:
一行一个数,表示 1 到 t 的最短路。
样例输入:
10 12 6
3 9 2
6 9 2
6 2 1
3 1 1
1 9 2
2 8 2
7 10 1
7 2 1
10 0 1
8 1 1
1 5 2
3 7 2
样例输出:
4
数据范围:
对于 30%的数据:n<=10,m<=20;
对于 60%的数据:n<=1 000,m<=20 000;
对于 100%的数据:n<=5 000 000,m<=10 000 000。
时空限制
注意下这道题时间限制:\(2.5ms\) 空间限制:\(1024MB\) 好大呀
思路
把因为边权只有可能是1和2,所以我们可以把边权为2的点拆成两条边,然后广搜~
最大的测试点还是达到了1.3+s QAQ 无能为力嘤嘤嘤~
代码
#include<bits/stdc++.h>
using namespace std;
#define MAXN 10000005
#define MAXM 20000005
#define INF 0x7f7f7f7f
int N, M, T;
int hd[MAXN], to[MAXM << 1], nxt[MAXM << 1], tot, dis[MAXN];
int Q[MAXN], ph(1), pt(0);
int x, y, z;
char B[150<<20], *S = B;
int read(){
int ans(0);
while( !isdigit(*S) ) S++;
while( isdigit(*S) ) ans = ans * 10 + ( (*S) ^ '0' ), S++;
return ans;
}
void Add( int x, int y ){
nxt[++tot] = hd[x]; to[tot] = y; hd[x] = tot;
nxt[++tot] = hd[y]; to[tot] = x; hd[y] = tot;
}
int main(){
freopen( "short.in", "r", stdin );
freopen( "short.out", "w", stdout );
fread( B, 1, 150 << 20, stdin );
N = read(); M = read(); T = read();
for ( int i = 1; i <= M; ++i ){
x = read(); y = read(); z = read();
if ( z & 1 ) Add( x, y );
else Add( x, ++N ), Add( y, N );
}
Q[++pt] = 1;
memset( dis, -1, sizeof dis ); dis[1] = 0;
while( pt >= ph ){
int t(Q[ph++]);
for ( int i = hd[t]; i; i = nxt[i] )
if ( dis[to[i]] < 0 ){
dis[to[i]] = dis[t] + 1, Q[++pt] = to[i];
if ( t == T ) break;
}
}
printf( "%d\n", dis[T] );
return 0;
}
「2018-12-02模拟赛」T1 最短路 解题报告的更多相关文章
- 「2018-11-05模拟赛」T5 传送机 解题报告
5.传送机(sent.*) 问题描述: 黄黄同学要到清华大学上学去了.黄黄同学很喜欢清华大学的校园,每次去上课时总喜欢把校园里面的每条路都走一遍,当然,黄黄同学想每条路也只走一遍. 我们一般人很可能对 ...
- 「2018-12-02模拟赛」T3 约束排列 解题报告
3.约束排列(place.pas/cpp/in/out) 问题描述: 给出 n 个互不相同的小写字母,表示出现的字符类型,以及 k 个约束关系: .....,表示 ai 必须出现在 bi 前面(ai, ...
- Solution -「牛客 NOIP 模拟赛」打拳
\(\mathcal{Description}\) 现 \(2^n\) 个人进行淘汰赛,他们的战力为 \(1\sim 2^n\),战力强者能战胜战力弱者,但是战力在集合 \(\{a_m\}\) 里 ...
- [NOI.AC 2018NOIP模拟赛 第三场 ] 染色 解题报告 (DP)
题目链接:http://noi.ac/contest/12/problem/37 题目: 小W收到了一张纸带,纸带上有 n个位置.现在他想把这个纸带染色,他一共有 m 种颜色,每个位置都可以染任意颜色 ...
- 「CSP-S模拟赛」2019第四场
「CSP-S模拟赛」2019第四场 T1 「JOI 2014 Final」JOI 徽章 题目 考场思考(正解) T2 「JOI 2015 Final」分蛋糕 2 题目 考场思考(正解) T3 「CQO ...
- #10471. 「2020-10-02 提高模拟赛」灌溉 (water)
题面:#10471. 「2020-10-02 提高模拟赛」灌溉 (water) 假设只有一组询问,我们可以用二分求解:二分最大距离是多少,然后找到深度最大的结点,并且把它的\(k\)倍祖先的一整子树删 ...
- #10470. 「2020-10-02 提高模拟赛」流水线 (line)
题面:#10470. 「2020-10-02 提高模拟赛」流水线 (line) 题目中的那么多区间的条件让人感觉极其难以维护,而且贪心的做法感觉大多都能 hack 掉,因此考虑寻找一些性质,然后再设计 ...
- 2018.12.02 Socket编程之初识Socket
Socket编程主要分为TCP/UDP/SCTP三种,每一种都有各自的优点,所以会根据实际情况决定选用何种Socket,今天开始我将会逐步学习Socket编程,并将学习过程记录于此. 今天学习的是TC ...
- 「NOIP模拟赛」数位和乘积(dp,高精)
统计方案数,要么组合数,要么递推(dp)了. 这是有模拟赛历史以来爆炸最狠的一次 T1写了正解,也想到开long long,但是开错了地方然后数组开大了结果100->0 T3看错题本来简单模拟又 ...
随机推荐
- A.The beautiful values of the palace 南京网络赛
A对于知道了解主席树性质的人来说,的确算是一个模板题目 题目在于给一个螺旋矩阵,以及一些权值,问在二维区间内权值和是多少? 对于螺旋矩阵权值来说,计算每个点的值,只需要O1计算即可.我们可以通过计算内 ...
- codeforces1217-edu
C The Number Of Good Substrings 我原来的基本思路也是这样,但是写的不够好 注意算前缀和的时候,字符串起始最好从1开始. #include<cstdio> # ...
- Python--day47--mysql分页性能相关方案
提高分页性能: 分页的时候,如果是正常的数据全局扫描,分页越大的时候花费的时间越长. 这时候要提高效率的话就不能全局扫描,如下面的例子,扫描索引且从最大或最小页开始扫描.
- hsqldb使用
1 hsqldb介绍 HyperSQL DataBase 是一个现代的关系数据库管理软件,比较彻底遵从SQL:2008标准和JDBC4规范.支持SQL:2008标准所以的核心特性和很多的可选特性. H ...
- 使用原生JS封装一个动画函数
最近一直在忙项目,很少有时间回顾之前的知识,今天刚好要做一个轮播,因为对兼容性有一定的要求,使用了各种插件和库中的轮播,效果都不是很理想,一怒之下,使用原生JS封装了一个轮播组件,其中重要的功能就是一 ...
- 【7003】&&【a203】合并多项式
Time Limit: 3 second Memory Limit: 2 MB 问题描述 求两个一元多项式的和.输入多项式方式为:多项式项数.每项系数和指数,按指数从大到小的顺序输入.输出多 ...
- Redis - 命令行工具
使用Redis内置的命令行工具 redis-cli一些便捷的命令: 1.执行单条命令 平时在访问 Redis 服务器,一般都会使用 redis-cli 进入交互模式,然后一问一答来读写服务器,这种情况 ...
- Java中的断言assert的用法
Java陷阱之assert关键字 一.概述 在C和C++语言中都有assert关键,表示断言. 在Java中,同样也有assert关键字,表示断言,用法和含义都差不多. 二.语法 在Java中,ass ...
- H3C保存当前配置--用户图示(console)以上
<H3C>save //此种保存只默认保存为Startup.cfg ,系统默认是加载此文件 The current configuration will be writte ...
- dotnet 启动 JIT 多核心编译提升启动性能
用2分钟提升十分之一的启动性能,通过在桌面程序启动 JIT 多核心编译提升启动性能 在 dotnet 可以通过让 JIT 进行多核心编译提升软件的启动性能,在默认托管的 ASP.NET 程序是开启的, ...