当前位置: 首页 > news >正文

东莞材料网站建设asp网站 换模板

东莞材料网站建设,asp网站 换模板,手机端企业网站模板,三网合一网站建设费用This way 题意: 给你一个有向图,1号点为起点,n为终点。你可以在k的倍数的时间点在起点开始,每条边的边长为1,同时,每条边有一个限定时间ai,表示你必须在大于等于ai的时间点才能走这条边。 …

This way

题意:

    给你一个有向图,1号点为起点,n为终点。你可以在k的倍数的时间点在起点开始,每条边的边长为1,同时,每条边有一个限定时间ai,表示你必须在大于等于ai的时间点才能走这条边。
    你需要在k的倍数的时间点到终点,问你在终点的最早时间,如果不存在输出-1.

题解:

    应当是一条最短路,在思考每条边的限定时间的时候会发现,假设这条边从a到b,边权为c。那么如果在d(d<c)的时刻到达a时,通不过,所以我们要么延迟k的倍数次从起点开始,使得到达a的时候是d+nk时刻,并且满足d+nk>=a且最小,要么就是绕个路再回到a点。
    于是我们发现这两种情况,第一种可以快速处理,不需要重新走一遍,直接假设已经是晚了nk的时间到达即可。
    第二种情况,假设再次到达a的时刻为e,满足e>=a,那么对于这种情况又细分为两种:
1.k|(e-d)也就是d+nk=e。这个就如同上一种情况一般假设晚到即可。
2.e!=d+nk,那么我思考至此发现,其实到达a的时候,总共只有k种情况,也就是:到达a位置的步长%k的不同情况。对于每一种情况,存下来最短路长即可。
    所以设置dis[i][j]表示到达i位置,走过的路长%k=j时,最短路程。知道了这个以后直接d。

#include<bits/stdc++.h>
using namespace std;
#define pii pair<int,int>
const int N=1e4+5,mx=1e9;
vector<pii>vec[N];
int dis[N][105],k,n,m;
struct node{int u,v,res;//pos,step,resbool operator< (const node& a)const {return v>a.v;}
};
priority_queue<node>Q;
int dij(){Q.push({1,0,0});dis[1][0]=0;while(!Q.empty()){node u=Q.top();Q.pop();if(u.v>dis[u.u][u.res])continue;for(pii ne:vec[u.u]){int nv;if(ne.second>u.v)nv=u.v+1+(ne.second-u.v+k-1)/k*k;else nv=u.v+1;int nr=nv%k;if(dis[ne.first][nr]>nv)dis[ne.first][nr]=nv,Q.push({ne.first,nv,nr});}}return dis[n][0];
}
int main()
{int x,y,z;scanf("%d%d%d",&n,&m,&k);for(int i=1;i<=n;i++)for(int j=0;j<k;j++)dis[i][j]=mx;for(int i=1;i<=m;i++){scanf("%d%d%d",&x,&y,&z);vec[x].push_back({y,z});}int ans=dij();if(ans==mx)printf("-1\n");else printf("%d\n",ans);return 0;
}
http://www.15wanjia.com/news/178101.html

相关文章:

  • 网站开发课程安排如何注册网站的名字
  • 您身边的网站建设专家龙华做网站怎么样
  • 农林网站建设公司wordpress微信群导航主题
  • DS716 II 做网站黑龙江电商网站建设
  • 各地残疾人联合会网站建设海尔网站建设的基本情况
  • 河源市规划建设局网站google网站排名
  • 为某网站做网站推广策划方案企业微信网站建设方案模板下载
  • 苏州做网站推广的外贸产品销量排名
  • 佛山公司网站设计团队php网站截图
  • 网站建设与维护的软件网站系统维护一般要多久
  • 政务网站建设 紧急通知丫个网站建设博客
  • 网站备案信息注销什么是黄页
  • 阿里云网站建设一次付费高端品牌运动鞋
  • 网站推广优势百度地图网站开发
  • 大连市英文网站建设抖音代运营收费标准参考
  • 如何网站关键词优化关于市场营销的培训课程
  • 沈阳网站备案查询建e网全景制作教程视频
  • 赣州建设监督网站制作企业网站的问题
  • 江苏网站推广网络软件推广的渠道是哪里找的
  • 做神秘顾客哪个网站好wordpress iis 500.50
  • 仿牌网站容易被攻击吗蚌埠网页设计
  • 南岗红旗大街网站建设网页制作基础教程做不出来
  • 仕德伟做的网站网站建设 推广400电话
  • js 网站源码网站服务器怎么看是哪个厂家的
  • 网站开发w亿玛酷1流量订制钱网站制作
  • 公司的网站怎么运营怎么在华为防火墙做网站映射
  • 找工作哪个网站好找跨境电商怎么注册
  • 网站设计网络推广商贸平台重庆厂区招工招聘信息查询
  • vps除了做网站还能做什么广州微网站建设
  • 网站开发培训什么石家庄网站模板建站