1084 - Winter
Time Limit: 2 second(s) Memory Limit: 32 MB

Winter is coming. In a land far away, N men are spending the nights in a valley in a largest field. The valley is so narrow that it can be considered to be a straight line running east-to-west.

Although standing in the valley does shield them from the wind, the group still shivers during the cold nights. They, like anyone else, would like to gather together for warmth.

Near the end of each day, each man i finds himself somewhere in the valley at a unique location Li. The men want to gather into groups of three or more persons since two persons just aren't warm enough. They want to be in groups before sunset, so the distance K each man can walk to form a group is limited. Determine the smallest number of groups the men can form.

Input

Input starts with an integer T (≤ 15), denoting the number of test cases.

Each case starts with two integers N (1 ≤ N ≤ 105) and K (1 ≤ K ≤ 106). Each of the next N line contains an integer Li (1 ≤ Li ≤ 108).

Output

For each case, print the case number and smallest number of groups the men can gather into. If there is no way for all the men to gather into groups of at least size three, output -1.

Sample Input

Output for Sample Input

2

6 10

2

10

15

13

28

9

3 1

1 10 20

Case 1: 2

Case 2: -1

Note

Dataset is huge, use faster I/O methods.

题意:N个人要在日落前都组成>=3的组,最多走距离k;问组成最少的组数;不能输出-1;

思路:本来自己想着贪心的,最后发现自己想错了,因为聚集点是不确定的,而且要的是最小的组,看了巨巨的有dfs还有bfs的;于是就借鉴了巨巨的思路;感觉应该是优先队列的,巨巨竟然不是优先队列也对了,膜拜;

bfs:

#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<queue>
#include<vector>
using namespace std;
const int INF=0x3f3f3f3f;
#define SI(x) scanf("%d",&x)
#define PI(x) printf("%d",x)
#define P_ printf(" ")
#define T_T while(T--)
#define mem(x,y) memset(x,y,sizeof(x))
const int MAXN=1e5+100;
int a[MAXN];
int N,K;
int vis[MAXN];
/*struct Node{
int l,r;
friend bool operator < (Node a,Node b){
if(a.l!=b.l)return a.l<b.l;
else return a.r<b.r;
}
};
Node d[MAXN];*/
struct Node{
int pos,gg;
friend bool operator < (Node a,Node b){
return a.gg>b.gg;
}
};
priority_queue<Node>dl;
int bfs(){
Node p,q;
mem(vis,0);
vis[0]=1;
while(!dl.empty())dl.pop();
p.pos=0;p.gg=0;
dl.push(p);
while(!dl.empty()){
p=dl.top();dl.pop();
int temp=p.pos;
if(temp>=N)return p.gg;
while(temp<N&&a[temp]-a[p.pos]<=2*K)temp++;
//PI(temp);puts("");
if(temp-p.pos>=3){
q.pos=temp;q.gg=p.gg+1;
if(!vis[q.pos])
dl.push(q);
vis[q.pos]=1;
}
if(temp-p.pos>=4){
q.pos=temp-1;q.gg=p.gg+1;
if(!vis[q.pos])
dl.push(q);
vis[q.pos]=1;
}
if(temp-p.pos>=5){
q.pos=temp-2;q.gg=p.gg+1;
if(!vis[q.pos])
dl.push(q);
vis[q.pos]=1;
}
}
return -1;
}
int main(){
int T,kase=0;
SI(T);
T_T{
SI(N);SI(K);
for(int i=0;i<N;i++)SI(a[i]);
sort(a,a+N);
//for(int i=0;i<N;i++)PI(a[i]),P_;puts("");
/*int l,r;
for(int i=0;i<N;i++){
d[i].l=lower_bound(a,a+N,a[i]-K)-a;
d[i].r=upper_bound(a,a+N,a[i]+K)-a-1;
}
sort(d,d+N);*/
printf("Case %d: %d\n",++kase,bfs());
}
return 0;
}

  dfs:

#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<queue>
#include<vector>
using namespace std;
const int INF=0x3f3f3f3f;
#define SI(x) scanf("%d",&x)
#define PI(x) printf("%d",x)
#define P_ printf(" ")
#define T_T while(T--)
#define mem(x,y) memset(x,y,sizeof(x))
const int MAXN=1e5+100;
int a[MAXN];
int N,K;
int vis[MAXN];
/*struct Node{
int pos,gg;
friend bool operator < (Node a,Node b){
return a.gg>b.gg;
}
};
priority_queue<Node>dl;
int bfs(){
Node p,q;
mem(vis,0);
vis[0]=1;
while(!dl.empty())dl.pop();
p.pos=0;p.gg=0;
dl.push(p);
while(!dl.empty()){
p=dl.top();dl.pop();
int temp=p.pos;
if(temp>=N)return p.gg;
while(temp<N&&a[temp]-a[p.pos]<=2*K)temp++;
//PI(temp);puts("");
if(temp-p.pos>=3){
q.pos=temp;q.gg=p.gg+1;
if(!vis[q.pos])
dl.push(q);
vis[q.pos]=1;
}
if(temp-p.pos>=4){
q.pos=temp-1;q.gg=p.gg+1;
if(!vis[q.pos])
dl.push(q);
vis[q.pos]=1;
}
if(temp-p.pos>=5){
q.pos=temp-2;q.gg=p.gg+1;
if(!vis[q.pos])
dl.push(q);
vis[q.pos]=1;
}
}
return -1;
}
int main(){
int T,kase=0;
SI(T);
T_T{
SI(N);SI(K);
for(int i=0;i<N;i++)SI(a[i]);
sort(a,a+N);
//for(int i=0;i<N;i++)PI(a[i]),P_;puts("");
printf("Case %d: %d\n",++kase,bfs());
}
return 0;
}*/
int ans,flot;
void dfs(int pos,int gg){
int temp=pos;
if(flot)return;
if(pos>=N){
flot=1;
ans=gg;
return;
}
while(temp<N&&a[temp]-a[pos]<=2*K)temp++;
if(!vis[temp])if(temp-pos>=3)vis[temp]=1,dfs(temp,gg+1);
if(!vis[temp-1])if(temp-pos>=4)vis[temp-1]=1,dfs(temp-1,gg+1);
if(!vis[temp-2])if(temp-pos>=5)vis[temp-2]=1,dfs(temp-2,gg+1);
}
int main(){
int T,kase=0;
SI(T);
T_T{
SI(N);SI(K);
for(int i=0;i<N;i++)SI(a[i]);
sort(a,a+N);
//for(int i=0;i<N;i++)PI(a[i]),P_;puts("");
flot=0;
mem(vis,0);
vis[0]=1;
dfs(0,0);
if(!flot)ans=-1;
printf("Case %d: %d\n",++kase,ans);
}
return 0;
}

  

Winter(bfs&&dfs)的更多相关文章

  1. POJ 2227 The Wedding Juicer (优先级队列+bfs+dfs)

    思路描述来自:http://hi.baidu.com/perfectcai_/item/701f2efa460cedcb0dd1c820也可以参考黑书P89的积水. 题意:Farmer John有一个 ...

  2. 邻结矩阵的建立和 BFS,DFS;;

    邻结矩阵比较简单,, 它的BFS,DFS, 两种遍历也比较简单,一个用队列, 一个用数组即可!!!但是邻接矩阵极其浪费空间,尤其是当它是一个稀疏矩阵的时候!!!-------------------- ...

  3. Collect More Jewels(hdu1044)(BFS+DFS)

    Collect More Jewels Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Othe ...

  4. Cleaning Robot (bfs+dfs)

    Cleaning Robot (bfs+dfs) Here, we want to solve path planning for a mobile robot cleaning a rectangu ...

  5. LeetCode:BFS/DFS

    BFS/DFS 在树专题和回溯算法中其实已经涉及到了BFS和DFS算法,这里单独提出再进一步学习一下 BFS 广度优先遍历 Breadth-First-Search 这部分的内容也主要是学习了labu ...

  6. 图的基本遍历算法的实现(BFS & DFS)复习

    #include <stdio.h> #define INF 32767 typedef struct MGraph{ ]; ][]; int ver_num, edge_num; }MG ...

  7. BFS/DFS算法介绍与实现(转)

    广度优先搜索(Breadth-First-Search)和深度优先搜索(Deep-First-Search)是搜索策略中最经常用到的两种方法,特别常用于图的搜索.其中有很多的算法都用到了这两种思想,比 ...

  8. NOIP2010引水入城[BFS DFS 贪心]

    题目描述 在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个N 行M 列的矩形,如上图所示,其中每个格子都代表一座城市,每座城市都有一个海拔高度. ...

  9. HDU 1044 Collect More Jewels(BFS+DFS)

    Collect More Jewels Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Othe ...

随机推荐

  1. 像jq那样获取对象的js原生方法

    使用过jq的童鞋非常喜欢jq获取对象的方法,只要$()就可以获取,在此我封装一个js获取对象的方法 [注意]只对chrome,Firefox,opera,Safari,ie8及ie8以上版本有效 fu ...

  2. unexpected token: null near line 1, column 290

    org.hibernate.hql.internal.ast.QuerySyntaxException: unexpected token: null near line 1, column 290 ...

  3. ROS验证publisher和subscriber

    在前面的两篇博客中我们用C++在ROS中创建了一个发布者和接收者,并使用catkin_make构建了新的节点,下面就需要验证一下,我们写的是否正确. 首先运行roscore roscore 在使用ca ...

  4. 解决ListView 和ScroolView 共存 listItem.measure(0, 0) 空指针

    在网上找到ListView 和ScroolView 共存的方法无非是给他每个listview 重新增加高度,但是android 的设计者始终认为这并不是一种好的实现方法.但是有的时候有必须要用这种蛋疼 ...

  5. R与数据分析旧笔记(一)基本数学函数的使用

    创建向量矩阵 > x1=c(2,3,6,8) > x2=c(1,2,3,4) > a1=(1:100) > length(a1) [1] 100 > length(x1) ...

  6. 为IE6-7间接支持:before和:after伪类

    :before和:after我们经常会用到,特别是在做移动端页面时,利用它制作文字前后的ICON.图片的垂直居中之类的非常方便且代码简洁(当然,功能远比这些要多的多...). 可是在PC端,由于现在还 ...

  7. hdu 3498 whosyourdaddy 重复覆盖

    题目链接 重复覆盖的入门题, 和精确覆盖不一样, 删除的时候只删除一行多列. #include<bits/stdc++.h> using namespace std; #define pb ...

  8. Android倒计时Button

    最近做用户绑定,需要用到倒计时的一个Button,就花点时间封装了一个,非常简单,效果图如下: 1.TimeButton 自定义倒计时Button package com.example.timebu ...

  9. 派生类地址比基类地址少4(子类与基类指针强行转换的时候,值居然会发生变化,不知道Delphi BCB是不是也这样) good

    大家对虚表并不陌生,都知道每个含有虚函数的类对象都有1个虚指针,但是在现实使用中,却总是因为这而调试半天,才发现原来是虚指针惹的祸.我这几天在调试代码时候也中招了,我的问题是这样的,如下图,CTree ...

  10. Android利用广播监听设备安装和卸载应用程序

    MainActivity如下: package cn.testappaddandremove; import android.os.Bundle; import android.app.Activit ...