man
Description
n间房子高度不同,Man 要从最矮的房子按照高度顺序跳到最高的房子,你知道房子的顺序,以及Man一次最远可以跳多远,相邻的房子至少有1的距离,房子的宽不计,现在由你安排相邻房子的距离,使Man可以跳到最高的房子且让最矮的房子与最高的房子距离最远,没有合法方案输出-1
Input
第一行一个整数T表示数据组数,每组数据第一行两个整数n,d分别表示房子数量以及Man一次可以跳多远,第二行n个整数用空格隔开,第i个整数表示第i个房子的高度
Output
每组数据输出‘Case ’+第几组数据+‘: ’+最远距离
Sample Input
样例输入:
3
4 4
20 30 10 40
5 6
20 34 54 10 15
4 2
10 20 16 13
样例输出:
Case 1: 3
Case 2: 3
Case 3: -1
HINT
数据范围:
对于40%的数据 n < 8 t=2 d < 10
对于100%的数据 n < 10001 d < 1000000 t < 100 高度 < 1000000
差分约束典型题…
关于如何理解 选取起点和终点中靠左边的点, 开始跑一遍最短路就可以得到答案, 这里提供一种思路: 在跑最短路之前, dis被设置为INF, 跑最短路的过程就是为了使dis满足约束条件. 只要跑完最短路, dis[t]必定就是最大的. 至于为什么要选取起点和终点中靠左的开始跑最短路, 理由是dis[t]维护的是s到t的距离的最大值. 这个假如t在s的左边, 则距离为负, 则维护的实际上是t到s的距离的最小值. 因此要确保起始遍历的点在终结点的左边.
#include<stdio.h>
#include<iostream>
#include<string.h>
#include<algorithm>
#include<math.h>
using namespace std;
const int maxN = 1000;
const int maxRoom = (int)1e6;
struct building
{
int h, id;
}a[maxN];
int head[maxN];
int top;
struct edge
{
int v, w, next;
}G[maxN << 2];
void addEdge(int u, int v, int w)
{
G[top].v = v;
G[top].w = w;
G[top].next = head[u];
head[u] = top ++;
}
int operator <(building x, building y)
{
return x.h < y.h;
}
int dis[maxN];
int Q[maxRoom];
int inQ[maxN];
int vis[maxN];
int main()
{
#ifndef ONLINE_JUDGE
freopen("man.in", "r", stdin);
freopen("man.out", "w", stdout);
#endif
ios::sync_with_stdio(false);
int T, _case = 0;
for(cin >> T; T; T --)
{
int n, d;
cin >> n >> d;
memset(head, - 1, sizeof(head));
top = 0;
for(int i = 0; i < n; i ++)
{
cin >> a[a[i].id = i].h;
if(i)
addEdge(i, i - 1, - 1);
}
sort(a, a + n);
for(int i = 1; i < n; i ++)
{
int u = a[i - 1].id, v = a[i].id;
if(u > v)
swap(u, v);
addEdge(u, v, d);
}
int L = 0, R = 1, s = a[0].id, t = a[n - 1].id;
if(s > t)
swap(s, t);
Q[L] = s;
memset(dis, 127, sizeof(dis));
dis[s] = 0;
memset(inQ, 0, sizeof(inQ));
inQ[s] = 1;
memset(vis, 0, sizeof(vis));
vis[s] = 1;
int flag = 0;
while(L < R)
{
int u = Q[L];
for(int i = head[u]; i != - 1; i = G[i].next)
{
int v = G[i].v;
if(dis[u] + G[i].w >= dis[v])
continue;
dis[v] = dis[u] + G[i].w;
if(! inQ[v])
{
inQ[v] = 1;
Q[R ++] = v;
vis[v] ++;
if(vis[v] > n)
{
flag = 1;
break;
}
}
}
inQ[u] = 0;
L ++;
}
if(flag)
printf("Case %d: -1\n", ++ _case);
else
printf("Case %d: %d\n", ++ _case, abs(dis[t]));
}
}
随机推荐
- R-barplot()
barplot这个函数啊...坑...度娘的很多解决方案都不对,只好重新看回manual再做测试== 本文参考的是: https://stat.ethz.ch/R-manual/R-devel/lib ...
- centos7 bond 和 网桥配置
rhel7系统bond配置(更新版本):https://www.cnblogs.com/zhangjianghua/p/9119808.html Bonding的模式一共有7种: 1.mode=0(b ...
- selenium2 页面对象模型Page Object
开发Selenium WebDriver测试时,可以使用页面对象模型,这样可使得测试脚本有更高的可维护性,减少了重复的代码,把页面抽象出来.同时页面对象模型也提供了一个注释,帮助缓存远程,避免出现元素 ...
- Hadoop4.2HDFS测试报告之六
测试结论 第一组数据作表格作图: 第二组数据作表格作图: 根据以上图分析得出以下结论: 1. 本地存储的读写速率基本保持23M左右,说明本地存储比较稳定. 2. HDFS存储两个数据节点的读写速率性能 ...
- HDU 1533 二分图最小权匹配 Going Home
带权二分图匹配,把距离当做权值,因为是最小匹配,所以把距离的相反数当做权值求最大匹配. 最后再把答案取一下反即可. #include <iostream> #include <cst ...
- Githun&HEXO建站小记
title: 建站小记 date: 2018-03-04 11:10:54 updated: 2018-03-06 12:00:00 tags: [hexo,next,建站,学习,前端技术,折腾,博客 ...
- const用法归纳总结 C++
非常好的一篇分析const的总结归纳, 在此谢谢原作者:http://blog.csdn.net/zcf1002797280/article/details/7816977 在普通的非 const成员 ...
- 解读Loadrunner网页细分图(Web Page Diagnostics)
[转载的地址]https://www.cnblogs.com/littlecat15/p/9456376.html 一.启用网页细分图 首先在Controller场景设计运行之前,需要在菜单栏中设置D ...
- 正则表达式 去除所有非ASCII字符
需求: 去除字符串中包含的所有外国字符 只能使用正则如下,找到包含非ASCII的记录 db=# select * from test where info ~ '[^(\x00-\x7f)]'; id ...
- javascript学习笔记 - 引用类型 单体内置对象
七 单体内置对象 1.Global对象 不属于任何对象的属性和方法,都归于它.全局作用域中定义的变量.函数,都属于Global对象 1.1 URI编码 encodeURI <=>deco ...