HDU 3830 Checkers
意甲冠军:
有三件 所有其他棋子可以跳 不能分开的两个跳跃 当被问及状态u为了国家v最低短跳转
思路:
对于一个状态三个棋子的位置能够设为 x y z (小到大)
仅仅有当y-x=z-y的时候 跳的方法为两种 即 y跳过x 或 y跳过z
在上式等式不成立时 短的一边能够跳很多次 直到大小关系改变
那么这样就形成了二叉树的结构 我们将y向左右跳的状态分别作为原状态的儿子 将两边当中一个向中间跳的状态作为原状态的父亲
那么这时u和v的可达性就变成了 他们是不是同一个根 于是我们能够从u和v跳到头 推断一下
假设能跳 要跳几次呢?? 这时利用LCA 方法与倍增法同样 即 u和v先爬到同一高度 再同一时候爬
爬的方法和刚才的状态向根移动同样 因为没有倍增打表 因此同一深度后我们要用二分法确定爬的高度
代码:
#include<cstdio>
#include<iostream>
#include<cstring>
#include<string>
#include<algorithm>
#include<map>
#include<set>
#include<vector>
#include<queue>
#include<cstdlib>
#include<ctime>
#include<cmath>
using namespace std;
typedef unsigned long long LL;
#define M 1100
#define N 16 struct state {
int x[3];
void Sort() {
sort(x, x + 3);
}
int Root() {
int floor = 0;
int a1 = x[1] - x[0], a2 = x[2] - x[1];
while (a1 != a2) {
if (a1 > a2) {
int d = (a1 - 1) / a2;
floor += d;
x[2] -= d * a2;
x[1] -= d * a2;
} else {
int d = (a2 - 1) / a1;
floor += d;
x[0] += d * a1;
x[1] += d * a1;
}
Sort();
a1 = x[1] - x[0], a2 = x[2] - x[1];
}
return floor;
}
bool operator==(const state ff) const {
return (x[0] == ff.x[0]) && (x[1] == ff.x[1]) && (x[2] == ff.x[2]);
}
void GoUp(int floor) {
while (floor) {
int a1 = x[1] - x[0], a2 = x[2] - x[1];
if (a1 > a2) {
int d = (a1 - 1) / a2;
if (d > floor)
d = floor;
floor -= d;
x[2] -= d * a2;
x[1] -= d * a2;
} else {
int d = (a2 - 1) / a1;
if (d > floor)
d = floor;
floor -= d;
x[0] += d * a1;
x[1] += d * a1;
}
Sort();
}
}
} u, v, fau, fav; int main() {
int fu, fv, ans;
while (~scanf("%d%d%d%d%d%d", &u.x[0], &u.x[1], &u.x[2], &v.x[0], &v.x[1],
&v.x[2])) {
u.Sort();
v.Sort();
fau = u;
fav = v;
fu = fau.Root();
fv = fav.Root();
if (fau == fav) {
puts("YES");
if (fu > fv) {
ans = fu - fv;
u.GoUp(ans);
} else if (fv > fu) {
ans = fv - fu;
v.GoUp(ans);
} else
ans = 0;
int l = 0, r = min(fu, fv), mid, tmp;
while (l <= r) {
mid = (l + r) >> 1;
fau = u;
fav = v;
fau.GoUp(mid);
fav.GoUp(mid);
if (fau == fav) {
r = mid - 1;
tmp = mid;
} else
l = mid + 1;
}
printf("%d\n", ans + (tmp << 1));
} else
puts("NO");
}
return 0;
}
版权声明:本文博客原创文章,博客,未经同意,不得转载。
HDU 3830 Checkers的更多相关文章
- HDU 3830 Checkers(二分+lca)
Description Little X, Little Y and Little Z are playing checkers when Little Y is annoyed. So he wan ...
- 最近公共祖先(LCA)模板
以下转自:https://www.cnblogs.com/JVxie/p/4854719.html 首先是最近公共祖先的概念(什么是最近公共祖先?): 在一棵没有环的树上,每个节点肯定有其父亲节点和祖 ...
- Tarjan & LCA 套题题目题解
刷题之前来几套LCA的末班 对于题目 HDU 2586 How far away 2份在线模板第一份倍增,倍增还是比较好理解的 #include <map> #include <se ...
- 【转载】图论 500题——主要为hdu/poj/zoj
转自——http://blog.csdn.net/qwe20060514/article/details/8112550 =============================以下是最小生成树+并 ...
- hdu图论题目分类
=============================以下是最小生成树+并查集====================================== [HDU] 1213 How Many ...
- HDU图论题单
=============================以下是最小生成树+并查集====================================== [HDU] 1213 How Many ...
- Tarjan LCA
强连通 迷宫城堡 Proving Equivalences Equivalent Sets Summer Holiday Intelligence System The King's Problem ...
- [tarjan] hdu 3836 Equivalent Sets
主题链接: http://acm.hdu.edu.cn/showproblem.php? pid=3836 Equivalent Sets Time Limit: 12000/4000 MS (Jav ...
- HDOJ 2111. Saving HDU 贪心 结构体排序
Saving HDU Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
随机推荐
- MyEclipse-6.5注冊码生成器源代码
打开MyEclipse新建一个Javaproject,然后新建类,粘贴例如以下代码,就可以生成MyEclipse的注冊码 import java.io.BufferedReader; import j ...
- 【Android】 -- 使用UncaughtExceptionHandler捕捉全局异常
在综合统计SDK(欧盟统计局的朋友,百度统计)之后.有一个非常有利的功能测试:错误分析.此功能可以在程序的执行中遇到崩溃(runtimeException)反馈给server,帮助开发者提高产品.多功 ...
- POJ 3481 & HDU 1908 Double Queue (map运用)
题目链接: PKU:http://poj.org/problem?id=3481 HDU:http://acm.hdu.edu.cn/showproblem.php?pid=1908 Descript ...
- <转载>如何解决子级用float浮动父级div高度不能自适应的问题
转载:http://www.kwstu.com/ArticleView/divcss_2013101582430202 解决子级对象使用css float浮动 而父级div不能自适应高度,不能被父级内 ...
- 发掘ListBox的潜力(一):自动调整横向滚动条宽度
<自绘ListBox的两种效果>一文帖出之后,从反馈信息来看,大家对这种小技巧还是很认同.接下来我将继续围绕ListBox写一系列的文章,进一步发掘ListBox的潜力,其中包括:自动调整 ...
- 一些关于Console的API函数
SetConsoleCtrlHandlerGenerateConsoleCtrlEventSetConsoleMode ReadConsole WriteConsole SetConsoleCP Se ...
- Mysql 执行计划分析
zjdev 正常访问: mysql> explain SELECT temp.* , -> (SELECT COUNT(sn) FROM AssignClientManager WHERE ...
- goldengate 简单配置 oracle to oralce
做oracle时配置的,goldengate 是同步异构数据库最好的工具.这个是基于oracle to oracle 单向复制 添加增量复制进程 add extract process -- -- ...
- Android 系统搜索框(有浏览记录)
实现Android 系统搜索框(有浏览记录),先看下效果: 一.配置搜索描述文件 要在res中的xml文件加创建sreachable.xml,内容如下: <?xml version=" ...
- C#数学运算表达式解释器
C#数学运算表达式解释器 測试文件内容: a=2+3*2; b=2*(2+3); 浏览按钮事件处理程序: private void button_browse_Click(object sender, ...