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]));
}
}

随机推荐

  1. golang连接orcale

    使用glang有一段时间了,最开始其实并不太喜欢他的语法,但是后来熟悉之后发现用起来还挺爽的.之前数据库一直使用mysql,连接起来没有什么问题,github上有很多完善的驱动,所以以为连接其他数据库 ...

  2. 2019 study list

    分析工具: (1)SQL   select from   where   group by having   order by   limit   运算符(算数运算符+-*/.比较运算符>< ...

  3. 请求报文&响应报文

    转自黑马程序员视频教程

  4. [转] Vuex入门(2)—— state,mapState,...mapState对象展开符详解

    1.state  state是什么? 定义:state(vuex) ≍ data (vue) vuex的state和vue的data有很多相似之处,都是用于存储一些数据,或者说状态值.这些值都将被挂载 ...

  5. JavaScript: 2015 年回顾与展望

    链接:http://www.sitepoint.com/javascript-2015-review/ JavaScript经历了一个不平凡的一年.尽管到5月份已经20年了,关于JS的新闻.项目和兴趣 ...

  6. LSTM block和cell区别

    LSTM的结构中每个时刻的隐层包含了多个memory blocks(一般我们采用一个block),每个block包含了包含一个Cell(有多个memory cell组成)和三个gate,一个基础的结构 ...

  7. 浅谈抓取网页数据(奉上Demo)

    Demo源码 背景 曾经在公司做过一个比价系统,就是抓取其它网站上商品的价格并和自己公司的商品进行对应,然后展示出来,给pm提供一个定价的参考.后来,有同事的朋友在找工作的时候,猎头让其做一个抓取去哪 ...

  8. 0014.Linux环境搭建 Python环境搭建

    -安装Linux-- 找了了老男孩19期的运维班安装视频,尼玛真心不想看书,文字枯燥的要死,还不如直接看视频进行安装... 可怜了我的C盘只有1GB了...绝对不能安装在C盘...那就安装在E盘吧,足 ...

  9. BZOJ4816 [Sdoi2017]数字表格 【莫比乌斯反演】

    题目 Doris刚刚学习了fibonacci数列.用f[i]表示数列的第i项,那么 f[0]=0 f[1]=1 f[n]=f[n-1]+f[n-2],n>=2 Doris用老师的超级计算机生成了 ...

  10. P1260 工程规划 (差分约束)

    题目链接 Solution 差分约束. 差分约束似乎精髓就两句话: 当我们把不等式整理成 \(d[a]+w<=d[b]\) 时,我们求最长路. 整理成 \(d[a]+w>=d[b]\) 时 ...