题目

\(n\)个点\(m\)条边的无向图,一条路径的代价定义为路径上前\(k\)大边的边权和

对于$k = n \to 1 $,求1-n的最短路

\(n,m \le 3000 \ , \ w_i \le 10^9\)

题解

  • 60pts
  • 枚举最小的边\(e\)将边分为 $ \ge e $ 和 $ <e $ ,后者边权设为0,设\(dp_{i,j}\)表示走到\(i\),\(\ge e\)的边走了\(j\)条的概率
  • 用\(dp_{n,k}\)去更新答案,需要预先做一边最短路考虑边数不够的情况
  • 时间复杂度:\(O(m^2n\ log \ m)\)
  • 100pts
  • 枚举最小的\(e\),将每条边的边权设置为\(max\{0,w - w_e\}\) ,做Dij,用\(dis_{n} + k \times w_e\)更新答案
  • 时间复杂度:\(O(mn \log m)\)
#include<bits/stdc++.h>
#define ll long long
#define inf 1e18 using namespace std; const int N=3010;
int T,n,m,o,hd[N],vis[N],del[N<<1],id[N<<1];
ll dis[N],ans[N]; struct Edge{int u,v,w,nt;}E[N<<1];
void adde(int u,int v,int w){
E[o]=(Edge){u,v,w,hd[u]};hd[u]=o++;
E[o]=(Edge){v,u,w,hd[v]};hd[v]=o++;
} bool cmp(int x,int y){return E[x].w==E[y].w?x<y:E[x].w<E[y].w;} struct data{
int u;ll w;
data(int _u=0):u(_u){w=dis[u];};
bool operator <(const data&A)const{return w>A.w;};
};
priority_queue<data>q; void dijkstra(int e){
for(int i=1;i<=n;++i)dis[i]=inf;
++T;dis[1]=0;q.push(1);
while(!q.empty()){
int u=q.top().u;q.pop();
if(vis[u]==T)continue;
vis[u]=T;
for(int i=hd[u];i;i=E[i].nt){
int v=E[i].v;
if(del[i]){
if(dis[v]>dis[u]){
dis[v]=dis[u];
if(vis[v]!=T)q.push(v);
}
}else{
if(dis[v]>dis[u]+E[i].w-e){
dis[v]=dis[u]+E[i].w-e;
if(vis[v]!=T)q.push(v);
}
}
}
}
for(int i=1;i<=n;++i)ans[i]=min(ans[i],dis[n]+1ll*e*i);
} int main(){
freopen("journey.in","r",stdin);
freopen("journey.out","w",stdout);
scanf("%d%d",&n,&m);o=1;
for(int i=1;i<=m;++i){
int u,v,w;
scanf("%d%d%d",&u,&v,&w);
adde(u,v,w);
}
for(int i=1;i<o;++i)id[i]=i;
sort(id+1,id+o,cmp);
for(int i=1;i<=n;++i)ans[i]=inf;
dijkstra(0);
for(int i=1;i<o;++i){
int now=id[i];
if(del[now])continue;
del[now]=del[now+1]=1;
dijkstra(E[now].w);
}
for(int i=n;i;--i)printf("%lld\n",ans[i]);
return 0;
}

【JZOJ5551】【20190625】旅途的更多相关文章

  1. seL4之hello-2旅途(完成更新)

    seL4之hello-2旅途 2016/11/19 13:15:38 If you like my blog, please buy me a cup of coffee. 回顾上周 seL4运行环境 ...

  2. 更多文章请访问"程序旅途”

    更多文章请访问我的个人独立博客 程序旅途

  3. P酱的冒险旅途(思维)

    P酱的冒险旅途 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit S ...

  4. iOS 开发者旅途中的指南针 - LLDB 调试技术

    文章转载于:iOS 开发者旅途中的指南针 - LLDB 调试技术 今天给大家介绍的内容,无关乎任何功能性开发技术,但又对开发的效率影响至深,这就是调试技术. 何为调试呢,比如我们用 print 函数在 ...

  5. UESTC--758--P酱的冒险旅途(模拟)

    P酱的冒险旅途 Time Limit: 1000MS   Memory Limit: 65535KB   64bit IO Format: %lld & %llu Submit Status ...

  6. hdu分类 Dynamic Programming(这是一场漫长的旅途)

    下面是difficulty 1的题 1003   Max Sum 最长递增子序列.非常经典,最棒的解法是在线算法O(n)的复杂度. 贴的呢,是用dp做的代码. 先是一个高亮的dp递推式,然后找到最大处 ...

  7. Android启示录——开始Android旅途

    为了明年可以开始进行android程序开发,开始从零开始学习android,仅以此代表第一步开始(*^_^*),开始搭建环境…… 1. 软件下载 http://developer.android.co ...

  8. 51Nod 1326 遥远的旅途

    题目描述: 一个国家有N个城市,这些城市被标为0,1,2,...N-1.这些城市间连有M条道路,每条道路连接两个不同的城市,且道路都是双向的.一个小鹿喜欢在城市间沿着道路自由的穿梭,初始时小鹿在城市0 ...

  9. 【51Nod】-1326 遥远的旅途

    Description 一个国家有 N 个城市, 这些城市被标为 0,1,2,...N-1. 这些城市间连有 M 条道路, 每条 道路连接两个不同的城市, 且道路都是双向的. 一个小鹿喜欢在城市间沿着 ...

随机推荐

  1. jwt的简单使用

    目录 简介 java版本 golang版本 简介 使用jwt对数据进行存储加密,分为java和golang版本. java版本 maven配置 <dependency> <group ...

  2. 整理:WPF中Binding的几种写法

    原文:整理:WPF中Binding的几种写法 目的:整理WPF中Bind的写法 <!--绑定到DataContext--> <Button Content="{Bindin ...

  3. kafka broker Leader -1引起spark Streaming不能消费的故障解决方法

    一.问题描述:Kafka生产集群中有一台机器cdh-003由于物理故障原因挂掉了,并且系统起不来了,使得线上的spark Streaming实时任务不能正常消费,重启实时任务都不行.查看kafka t ...

  4. python numPy模块 与numpy里的数据类型、数据类型对象dtype

    学习链接:http://www.runoob.com/numpy/numpy-tutorial.html 官方链接:https://numpy.org/devdocs/user/quickstart. ...

  5. 1.ZooKeeper ACL权限控制

    参考:https://blog.csdn.net/liuxiao723846/article/details/79391650 ZK 类似文件系统,Client 可以在上面创建节点.更新节点.删除节点 ...

  6. 导览Linux系统文件系统类型

    虽然对于普通用户来说可能并不明显,但在过去十年左右的时间里,Linux 文件系统已经发生了显著的变化,这使它们能够更好对抗损坏和性能问题. 如今大多数 Linux 系统使用名为 ext4 的文件系统. ...

  7. 生意bisynes单词bisynes商业

    英语bisynes商务概念的提出是改革的产物,有一个演变的过程:贸易部--商业部.外贸部--内贸部--内贸局--商务部.是内外贸一体化的概念. 中文名:商务 外文名:Business,Bisynes商 ...

  8. Java深入学习(4):Future模式

    Future模式: 其实相当于是前端的Ajax 比如我们使用多线程下载文件时候,每一个线程都会发送HTTP请求资源.而我如何知道,文件下载完毕呢? 也就是说,主线程如何获得子线程的执行结果呢? 创建多 ...

  9. android中fragment卡顿的原因

    首页的ViewPager有十几个Fragment,在快速切换的时候,容易产生卡顿现象. 二.分析当ViewPager切换到当前的Fragment时,Fragment会加载布局并显示内容,如果用户这时快 ...

  10. Cheat Engine 基本用法

    打开游戏 当前血量2620 打开Cheat Engine 扫描2620 掉点血 再次扫描2600 此时,会根据第一次扫描结果,再次扫描 扫描成功 将数据放到修改区,点击箭头 修改数据 双击Value进 ...