nssl1141,jzoj3470-最短路【SPFA,暴力】

正题

纪中题目链接:https://jzoj.net/senior/#main/show/3470


题目大意

在从起点经过k个标记点然后到终点的最短路。


解题思路

用SPFA求出起点和所有标记点的最短路,然后暴力枚举标记点到达顺序。
时间负责度:O(K(N+M)+k!)O(K(N+M)+k!)O(K(N+M)+k!)


code

#include<cstdio>
#include<queue>
#include<cstring>
#define ll long long
#define inf 1e18+1
#define N 50010
using namespace std;
struct line{long long to,next,w;
}a[N*2];
long long n,m,x,y,w,k,s,t,f[11][N],v[N],tot,ls[N],ans,mark[11],ok[11];
queue<int> q;
void addl()//加边
{scanf("%d%d%d",&x,&y,&w);a[++tot].to=y;a[tot].w=w;a[tot].next=ls[x];ls[x]=tot;
}
void spfa(long long x,long long num)//最短路
{q.push(x);v[x]=1;f[num][x]=0;while(!q.empty()){long long x=q.front();q.pop();for(long long i=ls[x];i;i=a[i].next){long long y=a[i].to;if(f[num][x]+a[i].w<f[num][y]){f[num][y]=f[num][x]+a[i].w;if(!v[y]){v[y]=true;q.push(y);}}}v[x]=false;}
}
void dfs(long long dep,long long sum,long long be)
{if(dep==k) sum+=f[be][t];//到终点if(sum>ans) return;//剪枝if(dep==k){ans=sum;}for(long long i=1;i<=k;i++)if(!ok[i]){ok[i]=1;dfs(dep+1,sum+f[be][mark[i]],i);ok[i]=0;}
}
int main()
{scanf("%lld%lld%lld%lld%lld",&n,&m,&k,&s,&t);for(long long i=1;i<=m;i++)addl();for(int j=0;j<N;j++) f[0][j]=inf;spfa(s,0);for(long long i=1;i<=k;i++)//标号点求最短路{for(int j=0;j<N;j++) f[i][j]=inf;scanf("%lld",&mark[i]);spfa(mark[i],i);}ans=inf;dfs(0,0,0);//搜索if(ans>=inf) printf("-1");else printf("%lld",ans);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/323583.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

糊涂工具类真是场景下请求http接口的案例

大家好&#xff0c;我是雄雄&#xff0c;欢迎关注微信公众号&#xff1a;雄雄的小课堂 现在是&#xff1a;2022年7月7日13:46:07 前言 今天有个这样的需求&#xff0c;PC端需要查看一下哪些天有数据&#xff0c;但是哪些有有没有数据我这边还看不出来&#xff0c;得请求别的系…

Java进阶学习路线

1、JVM &#xff08;1&#xff09;启动参数 1)heap -Xms<size> -Xmx<size> a.young and old generation -Xmn<size> -XX:NewSize<size> -XX:MaxNewSize<size> -XX:NewRatio<rate> -XX:SurvivorRatio<rate> -XX:MaxTenuri…

nssl1142,jzoj3487-剑与魔法【堆,贪心】

正题 纪中题目链接:https://jzoj.net/senior/#main/show/3487 题目大意 有两个东西 一个是表示可以选择这个东西&#xff0c;然后加x的价值。 一个是在这个操作之前不可以超过x个东西。 求最大价值 解题思路 我们考虑每个不能超过的操作&#xff0c;我们留下价值最大的。…

体验 ASP.NET Core 中的多语言支持(Localization)

首先在 Startup 的 ConfigureServices 中添加 AddLocalization 与 AddViewLocalization 以及配置 RequestLocalizationOptions &#xff08;这里假设使用英文与中文&#xff09;&#xff1a; public void ConfigureServices(IServiceCollection services) { services.AddLoca…

java中复杂业务情况下的集合操作(增减集合同步数据)

大家好&#xff0c;我是雄雄&#xff0c;欢迎关注微信公众号&#xff1a;雄雄的小课堂 现在是&#xff1a;2022年7月5日16:14:28 前言 今天分享个案例&#xff0c;需求是这样的&#xff1a;一个团组中是可以包含多个会员&#xff0c;在给团组创建训练方案时&#xff0c;本质上…

springboot整合spring @Cache和Redis

转载自 springboot整合spring Cache和Redis spring基于注解的缓存 对于缓存声明&#xff0c;spring的缓存提供了一组java注解: Cacheable:触发缓存写入。CacheEvict:触发缓存清除。CachePut:更新缓存(不会影响到方法的运行)。Caching:重新组合要应用于方法的多个缓存操作。…

段落分开

分三段 <!DOCTYPE html> <html><head></head><body><p>This is a paragraph.</p> <p>This is another paragraph.</p> <p>这是网页设计中定义段落的标记&#xff0c;称为开始标记&#xff0c;称为结束标记。把一…

辞旧迎新,新工作感悟!

大家好&#xff0c;我是雄雄&#xff0c;欢迎关注微信公众号&#xff1a;雄雄的小课堂 现在是&#xff1a;2022年6月21日22:33:34 公众号又好久没有更新啦。从以前的日更&#xff0c;到后来的周更&#xff0c;再到后来的月更……不知道会不会到不更的结局。。。 最近换工作了…

ASPNET Core 2.x中的Kestrel服务器

Kestrel是一个基于libuv的跨平台ASP.NET Core web服务器&#xff0c;libuv是一个跨平台的异步I/O库。ASP.NET Core模板项目使用Kestrel作为默认的web服务器。 Kestrel支持以下功能&#xff1a; HTTPS用于启用不透明升级的WebSockets位于Nginx之后的高性能Unix sockets Kestr…

全文搜索!收藏这篇Solr ElasticSearch 长文就可以搞定

转载自 全文搜索&#xff01;收藏这篇Solr ElasticSearch 长文就可以搞定 摘自&#xff1a;JaJian博кē Java后端技术编者说&#xff1a;文章从浅到深&#xff0c;描述了什么是全文搜索&#xff0c;为什么要使用全文搜索&#xff0c;Solr和ElasticSearch的发展和比较。文章比…

nssl1143,jzoj3493-三角形【排序,数学,几何】

正题 纪中题目链接:https://jzoj.net/senior/#main/show/3493 题目大意 给n点&#xff0c;求有多少个三角形。 ##解题思路 我们考虑在n个点中选取3个点的方案数&#xff0c;Cn3C_n^3Cn3​。然后不能组成三角形的情况只有3点共线。利用容斥原理我们可以用方案数减去不合法的方…

网页弹框弹出

完成这个功能需要在 弹框弹出 点击之后 才会显示内容 <!DOCTYPE html> <html><head><title>对话框测试</title><script>alert("对话框测试");</script></head><body>对话框测试&#xff1a;</body> …

字符串工具类总结(全)

文章目录前言代码展示大家好&#xff0c;我是雄雄&#xff0c;欢迎关注微信公众号&#xff1a;雄雄的小课堂 现在是&#xff1a;2022年7月9日18:53:37 前言 最近在项目过程中整理了一些常用的方法&#xff0c;于是将其抽出来形成一个工具类。 下面我来分享一下我自己整理的一…

Azure School与开源

距离Azure School(https://school.azure.cn/) 的正式上线时间&#xff0c;2017.8.3&#xff0c;已经过去了20多天了。这20多天得到了很多有帮助的建议和反馈&#xff0c;小伙伴们都很给力&#xff0c;互相帮助扶持&#xff0c;调整产品不正确的地方&#xff0c;快速迭代新的功能…

ssl提高组周六模拟赛【2018.9.8】

前言 开学后&#xff0c;新学年新气象&#xff0c;学校题库也迎来了新的改动&#xff0c;界面大改变&#xff0c;也可以比赛了。 所以这周就有比赛了&#xff0c;而在纪中被虐习惯后回来渴望继续被虐就来参加提高组模拟赛&#xff08;反正今年也参加提高组&#xff09; 成绩 …

select count(*)底层究竟干了啥么?

转载自 select count(*)底层究竟干了啥么&#xff1f; “SELECT COUNT( * ) FROM t” 是个再常见不过的 SQL 需求了。在 MySQL 的使用规范中&#xff0c;我们一般使用事务引擎 InnoDB 作为(一般业务)表的存储引擎&#xff0c;在此前提下&#xff0c;COUNT( * )操作的时间复杂…

linux系统中启动tomcat报错Cannot find /root/tomcat/bin/setclasspath.sh

今天在启动tomcat的时候莫名其妙的报了个这个错&#xff0c;在网上搜好多都说是要改配置文件啥的&#xff0c;都挺麻烦的。 我觉得我的问题不是配置文件的问题&#xff0c;就没有去改&#xff0c;找到了个新方法。 只需要在终端输入命令&#xff1a; unset CATALINA_HOME然后…

c关于数组的疑惑

#include<stdio.h>main(){char a[]"asdas";printf("%s\n",a);}不明白为什么【】【不需要加数字】 #include<stdio.h>main(){int a[]{1};printf("%d\n",a);}在这里插入代码片结果为很大的数

为什么不应该重写service方法

转载自 为什么不应该重写service方法 故事通常是这样开始的&#xff1a; 从前&#xff0c;有一个程序猿&#xff0c;他语重心长地对孙子说&#xff1a;“孩子&#xff0c;要是你以后写servlet&#xff0c;最好不要重写service方法啊” 孙子大为不解&#xff0c;程序猿又说&…

.net core之ACG小站爬虫(二)

紧跟着上一节说的文章&#xff0c;虽然已经放出了所写的全代码&#xff0c;但还是再解释一下另外一个页面的请求和分析过程吧。PS&#xff1a;又可以愉快的水一章了&#xff0c;咕嘿嘿。页面分析上回说到下载按钮的href属性是javascript:;伪协议&#xff0c;导致了新打开的页面…