【JZOJ5551】【20190625】旅途
题目
\(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】旅途的更多相关文章
- 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运行环境 ...
- 更多文章请访问"程序旅途”
更多文章请访问我的个人独立博客 程序旅途
- P酱的冒险旅途(思维)
P酱的冒险旅途 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit S ...
- iOS 开发者旅途中的指南针 - LLDB 调试技术
文章转载于:iOS 开发者旅途中的指南针 - LLDB 调试技术 今天给大家介绍的内容,无关乎任何功能性开发技术,但又对开发的效率影响至深,这就是调试技术. 何为调试呢,比如我们用 print 函数在 ...
- UESTC--758--P酱的冒险旅途(模拟)
P酱的冒险旅途 Time Limit: 1000MS Memory Limit: 65535KB 64bit IO Format: %lld & %llu Submit Status ...
- hdu分类 Dynamic Programming(这是一场漫长的旅途)
下面是difficulty 1的题 1003 Max Sum 最长递增子序列.非常经典,最棒的解法是在线算法O(n)的复杂度. 贴的呢,是用dp做的代码. 先是一个高亮的dp递推式,然后找到最大处 ...
- Android启示录——开始Android旅途
为了明年可以开始进行android程序开发,开始从零开始学习android,仅以此代表第一步开始(*^_^*),开始搭建环境…… 1. 软件下载 http://developer.android.co ...
- 51Nod 1326 遥远的旅途
题目描述: 一个国家有N个城市,这些城市被标为0,1,2,...N-1.这些城市间连有M条道路,每条道路连接两个不同的城市,且道路都是双向的.一个小鹿喜欢在城市间沿着道路自由的穿梭,初始时小鹿在城市0 ...
- 【51Nod】-1326 遥远的旅途
Description 一个国家有 N 个城市, 这些城市被标为 0,1,2,...N-1. 这些城市间连有 M 条道路, 每条 道路连接两个不同的城市, 且道路都是双向的. 一个小鹿喜欢在城市间沿着 ...
随机推荐
- texstudio基本设置
一开始默认为英文,在上面菜单栏,“option” 1.设置中文:options->general->language->zh-cn 2.编辑和查看按钮: 3.设置默认编译器:选项-& ...
- 类例程_java战斗程序
代码如下: package t11; import java.util.Random; public class Fight { String name; int life, attack, spee ...
- maven下载,上传设置
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0" xmlns:xsi="http://www.w3. ...
- 简要介绍Linux网络服务的种类
如果有人问你Linux最强大的功能是什么,你大概会回答“是网络功能”.Lmux操作系统的优势之一就是网络功能了,这包含比较稳定的系统资源分配,以及较为安全的网络防护能力,所以许多人都喜欢用它来进行网络 ...
- div css字间距
div:nth-child(1){ color: #FFFFFF; font-size: 13px; font-weight: bold; margin-bottom: 25px; letter-sp ...
- mysql 获取指定日期到指定日期 区间段的日期
第一种方法: cross join (就相当于mysql中的循环) CROSS JOIN 把两张表中的数据进行 N * M的组合,即笛卡尔积 这里的两张表利用 union all都有5条数据,所以进行 ...
- Java梗概
Java平台:J2SE(桌面).J2ME(逐渐被android取代).J2EE(企业级针对web程序) Java是在JVM虚拟机上运行,跨平台本质是在不同平台上运行JVM虚拟机 JRE = JVM+核 ...
- PHP公众号开发给用户发微信消息提醒功能
最近做的一个项目,当有用户有资金到账或者成员变动时需要给他发一条微信消息提示.针对这个,开始想使用模板消息,但是刚注册的公众号申请消息模板需要几天时间申请,在时间不足下选择了使用客服消息接口,微信文档 ...
- Tachyon内存文件系统快速入门
一.简介 Tachyon是介于磁盘存储和计算框架之间的一种中间件,用于实现分布式的内存文件读写等功能,实现分布式集群内部共享数据. 应用实例: 二.架构 1.心跳机制 在Tachyon中,心跳用于Ma ...
- MySQL数据库中字符串函数之left、right用法
语法 LEFT(str,len) Returns the leftmost len characters from the string str, or NULL if any argument is ...