这道题最后没过,估计是痛失省一了,现在来补一下,当时思路是对的应该是代码出了问题导致样例没过最后nc的除了2,一直WA

题意:

给一张联通图,有两个导航系统,其中一个系统认为第i条边的权值是Pi,另一个系统认为是Qi(给定Pi和Qi),然后每个导航系统对于每条边i有个判定

其中一个是hero(vi)+Pi>hero(ui)会报警一次,另一个系统是a(vi)+Qi>a(ui)会报警一次,ui是边i的一个结点vi是另一个结点,让求一条两个系统警告次数相加最少的一条路径。

思路:

先从终点n作为起点跑两次最短路,一个按Pi为权值,求出每个节点v的hero(v),第二次以Qi为权值,求出每个节点v的a(v)。

然后遍历每条边,用警告次数作为权值从1作为起点再跑一次最短路求出结果即可。最短路的求法我用了Dij+堆优化。

这个改正过的代码只过了样例,没法实际测试了,有不对的地方还请大佬指正。

样例数据:

Sample input

5 7
3 4 7 1
1 3 2 20
1 4 17 18
4 5 25 3
1 2 10 1
3 5 4 14
2 4 6 5

Sample output

1

#include <bits/stdc++.h>
using namespace std; const int maxn = 1e4 + ;
const int maxm = 5e4 + ;
const int inf = 0x3f3f3f3f;
struct edge{
int to, wp, wq, ww, next;
} ed[maxm*];
int n, m, head[maxn], tot;
int hero[maxn], a[maxn], dis[maxn];
bool vis[maxn];
inline void add( int u, int v, int p, int q ){
ed[tot].to = v;
ed[tot].wp = p;
ed[tot].wq = q;
ed[tot].ww = ;
ed[tot].next = head[u];
head[u] = tot ++;
} inline void dij1(int s){
memset( vis, , sizeof(vis) );
memset( hero, inf, sizeof(hero) );
priority_queue< pair<int, int> > q;
vis[s] = ;
hero[s] = ;
q.push( make_pair( , s ) );
while( !q.empty() ){
int u = q.top().second;
q.pop();
for( int i=head[u]; i!=-; i=ed[i].next ){
int v = ed[i].to;
if( hero[v]>hero[u]+ed[i].wp ){
hero[v] = hero[u]+ed[i].wp;
if( !vis[v] ){
vis[v] = ;
q.push( make_pair( -hero[v], v ) );
}
}
}
}
} inline void dij2(int s){
memset( vis, , sizeof(vis) );
memset( a, inf, sizeof(a) );
priority_queue< pair<int, int> > q;
a[s] = ;
q.push( make_pair( , s ) );
while( !q.empty() ){
int u = q.top().second;
q.pop();
if( vis[u] ) continue;
vis[u] = ;
for( int i=head[u]; i!=-; i=ed[i].next ){
int v = ed[i].to;
if( a[v]>a[u]+ed[i].wq ){
a[v] = a[u]+ed[i].wq;
q.push( make_pair(-a[v], v) );
}
}
}
} inline void dij3( int s ){
memset( vis, , sizeof(vis) );
memset( dis, inf, sizeof(dis) );
priority_queue< pair<int, int> > q;
dis[s] = ;
q.push( make_pair( , s ) );
while( !q.empty() ){
int u = q.top().second;
q.pop();
if( vis[u] ) continue;
vis[u] = ;
for( int i=head[u]; i!=-; i=ed[i].next ){
int v = ed[i].to;
if( dis[v]>dis[u]+ed[i].ww ){
dis[v] = dis[u]+ed[i].ww;
q.push( make_pair( -dis[v], v ) );
}
}
}
} inline void bfs(int s){
queue<int> q;
memset( vis, , sizeof(vis) );
vis[s] = ;
q.push(s);
while( !q.empty() ){
int u = q.front();
q.pop();
for( int i=head[u]; i!=-; i=ed[i].next ){
int v = ed[i].to;
if( !vis[v] ){
vis[v] = ;
if( hero[v]+ed[i].wp>hero[u] ) ed[i].ww ++;
if( a[v]+ed[i].wq>a[u] ) ed[i].ww ++;
}
}
}
} int main(){
// freopen("in.txt", "r", stdin);
tot = ;
memset( head, -, sizeof(head) );
scanf("%d%d", &n, &m);
for( int i=; i<m; i++ ){
int u, v, p, q;
scanf("%d%d%d%d", &u, &v, &p, &q);
add( u, v, p, q );
add( v, u, p, q );
}
dij1(n);
dij2(n);
//注释掉的就是当时写的错误遍历边的代码
// for( int i=1; i<=n; i++ ){
// for( int j=head[i]; j!=-1; j=ed[j].next ){
// if( ed[j].wp+hero[ed[j].to]>hero[i] ) ed[j].ww ++;
// if( ed[j].wq+a[ed[j].to]>a[i] ) ed[j].ww ++;
// }
// }
bfs(); //应该从1开始向外bfs遍历边,即可找出正确答案
dij3();
printf("%d\n", dis[n]); return ;
}

2019安徽省程序设计竞赛 D.自驾游(最短路)的更多相关文章

  1. 2019安徽省程序设计竞赛 I.你的名字(序列自动机)

    这题和今年南昌邀请网络预选赛M题很像啊,不过主串数量不是一个了 都是在主串中判断子串是不是属于主串的一个子序列 #include <iostream> #include <cstri ...

  2. 2019中山大学程序设计竞赛 Triangle

    今天水了一发hdu上的中山校赛 这个题交了将近十遍才过...... 就是说给 n 个木棍,如果能找出3个能组成三角形的木棍就输出yes 反之输出no 乍一看很简单 一个排序遍历一遍就好了 但是n值太大 ...

  3. 2019中山大学程序设计竞赛-Monitor

    题目地址 题目大意:给你一个n*m的矩形,在这个矩形内告诉你p个矩形(左下角和右上角坐标),问你q个问题,每次也是给你一个矩形(左下角和右上角坐标),问你每个矩形是否可以被开始给的p个矩形完全覆盖. ...

  4. 2019中山大学程序设计竞赛(重现赛) Clumsy Keke

    Problem Description Keke is currently studying engineering drawing courses, and the teacher has taug ...

  5. 吉首大学2019年程序设计竞赛(重现赛)D - 数列求和(嘤雄难度)

    链接:https://ac.nowcoder.com/acm/contest/992/D $a_{i}=\dfrac {3a_{i-1}-a_{i-2}}{2}+i+1$ 移项再化一下 $a_{i}- ...

  6. 吉首大学2019年程序设计竞赛(重现赛)- A SARS病毒 (矩阵,欧拉降幂)

    题目链接:https://ac.nowcoder.com/acm/contest/992/A 题意:求出长度为n的字符串个数,字符串由A.C.G.T组成,其中A和C必须成对出现. 思路:我们规定:   ...

  7. 吉首大学2019年程序设计竞赛(重现赛)-K(线段树)

    题目链接:https://ac.nowcoder.com/acm/contest/992/K 题意:给一个大小为1e5的数组,由0 1组成,有两种操作,包括区间修改,将一段区间内的0换成1,1换成0; ...

  8. 吉首大学2019年程序设计竞赛(重现赛)-J(树形DP)

    题目链接:https://ac.nowcoder.com/acm/contest/992/J 题意:题意很清晰,就是求任意两点距离的和,结果对1e9+7取模. 思路:裸的树形DP题,一条边的贡献值=这 ...

  9. 吉首大学2019年程序设计竞赛-F 天花乱坠

    题目链接:https://ac.nowcoder.com/acm/contest/992/F 题意:给定正n边形,边长为100,以每条边的中点连线构成新的正n边形,无限循环下去,求所有边的长度和. 思 ...

随机推荐

  1. WeQuant教程—1.2 从简单的量化系统开始

    你大概知道量化的思想最早在古巴比伦人计算行星轨迹的时候就已经诞生(算术运算),后来借助古希腊的形式化逻辑的发展,人们日益能从量化的思想中提炼和描述自然规律并运用到生产之中.不过,基于量化的思想打造一个 ...

  2. win7安装 truffle

    1. 最近有个项目需要用到区块链,第一次玩不太熟悉.现在电脑上安装个  truffle,作为一个区块链节点 2. 安装 truffle ,之前需要安装其他几个软件 truffle的安装需要首先装有:n ...

  3. 深度学习-强化学习(RL)概述笔记

    强化学习(Reinforcement Learning)简介 强化学习是机器学习中的一个领域,强调如何基于环境而行动,以取得最大化的预期利益.其灵感来源于心理学中的行为主义理论,即有机体如何在环境给予 ...

  4. 4. Spark Streaming解析

    4.1 初始化StreamingContext import org.apache.spark._ import org.apache.spark.streaming._ val conf = new ...

  5. 实现动态WEB内容

    在 system1 上配置提供动态web内容,要求: 1.动态内容由名为 wsgi.group8.example.com 的虚拟主机提供 2.虚拟主机侦听在端口 8909 3.从 http://ser ...

  6. Linux 6 修改ssh默认远程端口号

    linux 默认的ssh远程端口是22,有时默认端口会遭到别有用心的人们扫描或攻击,为了时我们的系统更加安全那就需要修改远程端口号 操作步骤:1.修改ssh_config配置文件 vim /etc/s ...

  7. 4.将验证添加到 ASP.NET Core Razor 页面

    向 Movie 模型添加了验证逻辑. 每当用户创建或编辑电影时,都会强制执行验证规则. 1.打开Movie.cs文件.DataAnnotations命名空间提供了一组内置的验证属性,这些属性以声明方式 ...

  8. 中控考勤机使用 zkemkeeper SDK订阅考勤数据事件失效解决方式

    问题 前同事编写的对中控考勤机数据集成项目当中,打卡数据不能实时进行上传到平台当中,一直靠定时全量上传来同步数据. 阅读代码后,发现代码中有实时上传数据的逻辑,但是运行一段时间后,中控zkemkeep ...

  9. 关于.Net使用企业库访问MySql数据库

    关于.Net使用企业库访问MySql数据库 在网上看了很多又重写又加WebConfig中的内容,其实不用那么麻烦 企业库5.0访问MySql数据库只需要在Web服务器安装mysql-connector ...

  10. 【开发笔记】- QQ消息轰炸

    1.右键新建一个文本文件: 2.打开记事本将如下代码复制过去: On Error Resume Next Dim wsh,ye set wsh=createobject("wscript.s ...