UVA12569-Planning mobile robot on Tree (EASY Version)(BFS+状态压缩)
Problem UVA12569-Planning mobile robot on Tree (EASY Version)
Accept:138 Submit:686
Time Limit: 3000 mSec
Problem Description

Input
The first line contains the number of test cases T (T ≤ 340). Each test case begins with four integers n, m, s, t (4 ≤ n ≤ 15, 0 ≤ m ≤ n−2, 1 ≤ s,t ≤ n, s ̸= t), the number of vertices, the number of obstacles and the label of the source and target. Vertices are numbered 1 to n. The next line contains m different integers not equal to s, the vertices containing obstacles. Each of the next n − 1 lines contains two integers u and v (1 ≤ u < v ≤ n), that means there is an edge u−v in the tree.
Output
For each test case, print the minimum number of moves k in the first line. Each of the next k lines containstwointegers a and b,thatmeanstomovetherobot/obstaclefrom a to b. Ifthereisnosolution, print ‘-1’. If there are multiple solutions, any will do. Print a blank line after each test case.
Sample Input
4 1 1 3
2
1 2
2 3
2 4
6 2 1 4
2 3
1 2
2 3
3 4
2 5
2 6
8 3 1 5
2 3 4
1 2
2 3
3 4
4 5
1 6
1 7
2 8
Sample Ouput
2 4
1 2
2 3
2 6
3 2
2 5
1 2
2 3
3 4
1 7
2 1
1 6
7 1
1 2
2 8
3 2
2 1
1 7
4 3
3 2
2 1
8 2
2 3
3 4
4 5
#include <bits/stdc++.h> using namespace std; const int maxn = ;
int n, m, s, t;
int ori; struct Edge {
int to, next;
}edge[maxn << ]; struct Node {
int sit, robot;
int time;
Node(int sit = , int robot = , int time = ) :
sit(sit), robot(robot), time(time) {}
}; int tot, head[maxn];
pair<int,int> pre[][maxn];
bool vis[][maxn]; void init() {
tot = ;
memset(head, -, sizeof(head));
memset(pre, -, sizeof(pre));
memset(vis, false, sizeof(vis));
} void AddEdge(int u, int v) {
edge[tot].to = v;
edge[tot].next = head[u];
head[u] = tot++;
} inline int get_pos(int x) {
return << x;
} int bfs(pair<int,int> &res) {
queue<Node> que;
que.push(Node(ori, s, ));
vis[ori][s] = true; while (!que.empty()) {
Node first = que.front();
que.pop();
if (first.robot == t) {
res.first = first.sit, res.second = first.robot;
return first.time;
}
int ssit = first.sit, rrob = first.robot;
//printf("%d %d\n", ssit, rrob); for (int i = head[rrob]; i != -; i = edge[i].next) {
int v = edge[i].to;
if (ssit&get_pos(v) || vis[ssit][v]) continue;
vis[ssit][v] = true;
que.push(Node(ssit, v, first.time + ));
pre[ssit][v] = make_pair(ssit, rrob);
} for (int i = ; i < n; i++) {
if (ssit&(get_pos(i))) {
for (int j = head[i]; j != -; j = edge[j].next) {
int v = edge[j].to;
if (v == rrob || (ssit & get_pos(v))) continue;
int tmp = ssit ^ get_pos(v);
tmp ^= get_pos(i);
if (vis[tmp][rrob]) continue;
vis[tmp][rrob] = true;
que.push(Node(tmp, rrob, first.time + ));
pre[tmp][rrob] = make_pair(ssit, rrob);
}
}
}
}
return -;
} void output(pair<int,int> a) {
if (a.first == ori && a.second == s) return;
output(pre[a.first][a.second]);
int ppre = pre[a.first][a.second].first, now = a.first; if (ppre^now) {
int b = -, c = -;
for (int i = ; i < n; i++) {
if (((ppre & ( << i)) == ( << i)) && ((now & ( << i)) == )) {
b = i;
}
else if (((ppre & ( << i)) == ) && ((now & ( << i)) == ( << i))) {
c = i;
}
}
printf("%d %d\n", b + , c + );
}
else {
printf("%d %d\n", pre[a.first][a.second].second + , a.second + );
}
} int con = ; int main()
{
int iCase;
scanf("%d", &iCase);
while (iCase--) {
init();
scanf("%d%d%d%d", &n, &m, &s, &t);
s--, t--;
ori = ;
int x;
for (int i = ; i <= m; i++) {
scanf("%d", &x);
x--;
ori ^= get_pos(x);
} int u, v;
for (int i = ; i <= n - ; i++) {
scanf("%d%d", &u, &v);
u--, v--;
AddEdge(u, v);
AddEdge(v, u);
} pair<int, int> res;
int ans = bfs(res);
printf("Case %d: %d\n", con++, ans);
if (ans != -) output(res);
printf("\n");
}
return ;
}
UVA12569-Planning mobile robot on Tree (EASY Version)(BFS+状态压缩)的更多相关文章
- UVA-12569 Planning mobile robot on Tree (EASY Version) (BFS+状态压缩)
题目大意:一张无向连通图,有一个机器人,若干个石头,每次移动只能移向相连的节点,并且一个节点上只能有一样且一个东西(机器人或石头),找出一种使机器人从指定位置到另一个指定位置的最小步数方案,输出移动步 ...
- Uva 12569 Planning mobile robot on Tree (EASY Version)
基本思路就是Bfs: 本题的一个关键就是如何判段状态重复. 1.如果将状态用一个int型数组表示,即假设为int state[17],state[0]代表机器人的位置,从1到M从小到大表示障碍物的位置 ...
- UVA Planning mobile robot on Tree树上的机器人(状态压缩+bfs)
用(x,s)表示一个状态,x表示机器人的位置,s表示其他位置有没有物体.用个fa数组和act数组记录和打印路径,转移的时候判断一下是不是机器人在动. #include<bits/stdc++.h ...
- 2019.03.09 codeforces620E. New Year Tree(线段树+状态压缩)
传送门 题意:给一棵带颜色的树,可以给子树染色或者问子树里有几种不同的颜色,颜色值不超过606060. 思路:颜色值很小,因此状压一个区间里的颜色用线段树取并集即可. 代码: #include< ...
- Codeforces Round #540 (Div. 3) F1. Tree Cutting (Easy Version) 【DFS】
任意门:http://codeforces.com/contest/1118/problem/F1 F1. Tree Cutting (Easy Version) time limit per tes ...
- Ping-Pong (Easy Version)(DFS)
B. Ping-Pong (Easy Version) time limit per test 2 seconds memory limit per test 256 megabytes input ...
- ZOJ 3868 - Earthstone: Easy Version
3868 - Earthstone: Easy Version Time Limit:2000MS Memory Limit:65536KB 64bit IO Format:%lld ...
- Codeforces 1077F1 Pictures with Kittens (easy version)(DP)
题目链接:Pictures with Kittens (easy version) 题意:给定n长度的数字序列ai,求从中选出x个满足任意k长度区间都至少有一个被选到的最大和. 题解:$dp[i][j ...
- Coffee and Coursework (Easy version)
Coffee and Coursework (Easy version) time limit per test 1 second memory limit per test 256 megabyte ...
随机推荐
- lua的多种实现方式(1-100的和)
function add( a, b ) return a + b end -- print( add( 10, 20 ) ) function loopT( T ) for i, v in ipai ...
- DevExpress ChartControl ViewType.Line
源码地址:https://files.cnblogs.com/files/lanyubaicl/ChartControl.Line.7z public partial class Form1 : Fo ...
- webpack安装
npm install -g webpack webpack-dev-server
- 洛谷P2421 [NOI2002]荒岛野人(扩展欧几里得)
题目背景 原 A-B数对(增强版)参见P1102 题目描述 克里特岛以野人群居而著称.岛上有排列成环行的M个山洞.这些山洞顺时针编号为1,2,…,M.岛上住着N个野人,一开始依次住在山洞C1,C2,… ...
- Java NIO 学习
Java NIO提供了与标准IO不同的IO工作方式: Channels and Buffers(通道和缓冲区):标准的IO基于字节流和字符流进行操作的,而NIO是基于通道(Channel)和缓冲区(B ...
- IDEA项目搭建十三——服务消费端与生产端通信实现
一.简介 之前已经完成了EurekaClient的服务生产者和Feign的服务消费者模块的搭建,现在实现统一的通信约定 (1) 统一Request结构 (2) 统一Response结构 (3) 统一E ...
- 整理一些.net core中的错误代码
在hosting .net core时,有些错误代码并不容易理解. 作为标记,方便查询,这些错误代码可能不会出现在VS的错误查找工具里,也不会出现在错误代码转字符描述的函数里. COR_E_AMBIG ...
- spark查看DF的partition数目及每个partition中的数据量【集群模式】
println("--------------------"+data.rdd.getNumPartitions) // 获取DF中partition的数目 val partiti ...
- C#-简介(一)
1.C#语言简介 C#计算机语言 是一门高级计算机语言 他的开发模式更接近人类和社会的思维模式,有助于提高开发效率 C#历史 1998年COOL这个项目是C#语言的前身,由微软 Anders Hejl ...
- 洗礼灵魂,修炼python(63)--爬虫篇—re模块/正则表达式(1)
爬虫篇前面的某一章了,我们要爬取网站页面源代码的数据,要从中获取到我们想要的数据,是不是感觉很费力,确实费力对吧?那么有没有什么有利的工具来解决这个问题呢?那就是这一篇博文的主题—— 正则表达式简介 ...