HDU 3440House Man(差分约束)
q; q.push( s ); dis[s] = 0; while( !q.empty() ) { int u = q.front(); q.pop(); vis[u] = 0; for(int i=head[u];i;i=d[i].nxt ) { int v = d[i].to; if( dis[v]>dis[u]+d[i].w ) { dis[v] = dis[u]+d[i].w; if( !vis[v] ) { q.push( v ),vis[v] = 1; if( ++num[v]==n ) return false; } } } } return 1;}int main(){ int t,casenum = 0; cin >> t; while( t-- ) { cin >> n >> m; for(int i=1;i<=n;i++) { cin >> a[i].h, a[i].id = i; if( i>=2 ) add( i,i-1,-1 ); } sort( a+1,a+1+n ); for(int i=2;i<=n;i++) { int u = a[i-1].id, v = a[i].id; if( u>v ) swap(u,v); add( u,v,m ); } int u = a[1].id, v = a[n].id; if( u>v ) swap(u,v); cout << "Case " << ++casenum << ": "; if( spfa(u) ) cout << dis[v] << endl; else cout << "-1\n"; cnt = 1; for(int i=1;i<=n;i++) head[i] = 0; }}
发布日期:2021-06-30 10:24:41
浏览次数:2
分类:技术文章
本文共 1433 字,大约阅读时间需要 4 分钟。
题意:
要从高度最低的地方跳到高度最高的地方 每次跳跃的距离小于等于d
每次只能跳到下一个比他高但是和他高度最接近的位置
每个位置都有一个高度值 并且顺序不能换 最低和最高的最远距离。
定义 s [ i ] s[i] s[i]为点 i i i在的位置,这保证了相对位置
可以得到 s [ i ] > s [ i − 1 ] s[i]>s[i-1] s[i]>s[i−1]
然后对于高度差相邻的两个序号 u , v u,v u,v为了保证能跳过去
得到 s [ u ] − s [ v ] < = d s[u]-s[v]<=d s[u]−s[v]<=d
而且这里一定需要 u > v u>v u>v,因为 u u u在序号上大,所以要远一些的
而且最后是从最矮的位置跑最短路还是从最高的位置,也需要用序号大小来判断
#includeusing namespace std;const int maxn = 2e5+10;const int inf = 1e9;struct edge{ int to,nxt,w;}d[maxn]; int head[maxn],cnt=1;struct point{ int id,h; bool operator < (const point&tmp ) const{ return h
转载地址:https://issue-is-vegetable.blog.csdn.net/article/details/109964132 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
关注你微信了!
[***.104.42.241]2024年05月02日 09时49分37秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
leetcode3 无重复字符的最长子串
2019-04-30
leetcode 76 最小覆盖子串
2019-04-30
leetcode 1143. 最长公共子序列
2019-04-30
leetcode 83. 删除排序链表中的重复元素
2019-04-30
智能体 Intelligent Agent
2019-04-30
Network Compression网络压缩(一)
2019-04-30
GAN系列(零)—— GAN的发展(两条路线)
2019-04-30
Conditional GAN (CGAN) 条件生成网络
2019-04-30
强化学习(三) —— Policy Gradient 策略梯度
2019-04-30
docker安装oracle(win10)
2019-04-30
Cloudera Quickstart & HUE
2019-04-30
HUE
2019-04-30
CDH
2019-04-30
行为树 BT
2019-04-30
Cassandra & CQL
2019-04-30
Oracle数据库
2019-04-30
Oracle数据库命令
2019-04-30
plsql
2019-04-30
有限状态机FSM
2019-04-30
Win10 Docker
2019-04-30