题目描述

Hzwer的跳跳棋是在一条数轴上进行的。棋子只能摆在整点上。每个点不能摆超过一个棋子。

某一天,黄金大神和cjy用跳跳棋来做一个简单的游戏:棋盘上有3颗棋子,分别在a,b,c这三个位置。他们要通过最少的跳动把它们的位置移动成x,y,z。(棋子是没有区别的)

跳动的规则很简单,任意选一颗棋子,对一颗中轴棋子跳动。跳动后两颗棋子距离不变。一次只允许跳过1颗棋子。

写一个程序,首先判断是否可以完成任务。如果可以,输出最少需要的跳动次数。

输入

第一行包含三个整数,表示当前棋子的位置a b c。(互不相同)

第二行包含三个整数,表示目标位置x y z。(互不相同)

输出

如果无解,输出一行NO。

如果可以到达,第一行输出YES,第二行输出最少步数。

样例输入

1 2 3
0 3 5

样例输出

YES
2

提示

【范围】

20% 输入整数的绝对值均不超过10

40% 输入整数的绝对值均不超过10000

100% 绝对值不超过10^9

最近公共祖先

对于一个状态,例如2 3 7

中间可以往两侧跳,即2 3 7->1 2 7 / 2 3 7->2 7 11

两侧仅有靠近中间的能往中间跳,即2 3 7->3 4 7

那么所有的状态就能表示为一棵二叉树,第一种情况为其两个儿子,第二种为其父亲

但其实第一种情况并不重要,因为lca是一直找父亲,显然,根节点的三个棋是一个等差数列

问题转换为给定树上的两个结点,求其距离。如果两个节点

我们发现若记前两个数差t1,后两个数差t2,不妨设t1<t2

则左边最多往中间跳(t2-1)/t1次

然后只能右边往中间跳,是一个辗转相除的过程,即在logK的时间内我们可以用这种方法得到某个结点它向上K次后的结点,或者根节点,同时还可以顺便算下深度

很明显,如果初始情况和最终情况的根节点不一样,那么一定无解

那么只要求始终两个状态的深度d1,d2,将较深的调整到同一深度

然后二分/倍增求与lca的深度差x

ans=2*x+abs(d1-d2)

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
using namespace std;
struct xxx{int c[5];
}a,b;
int dep;
xxx zou(xxx aa,int x)
{xxx xx;int t1=aa.c[2]-aa.c[1],t2=aa.c[3]-aa.c[2];if(t1==t2)return aa;if(t1<t2){int yy=min(x,(t2-1)/t1);dep+=yy;x-=yy;xx.c[1]=aa.c[1]+yy*t1;xx.c[2]=aa.c[2]+yy*t1;xx.c[3]=aa.c[3];}if(t1>t2){int yy=min(x,(t1-1)/t2);dep+=yy;x-=yy;xx.c[1]=aa.c[1];xx.c[2]=aa.c[2]-yy*t2;xx.c[3]=aa.c[3]-yy*t2;}if(!x)return xx;else return zou(xx,x);
}
bool bj(xxx a,xxx b)
{for(int i=1;i<=3;i++)if(a.c[i]!=b.c[i])return 0;return 1;
}
int main()
{int ans=0;for(int i=1;i<=3;i++)scanf("%d",&a.c[i]);for(int i=1;i<=3;i++)scanf("%d",&b.c[i]);sort(a.c+1,a.c+4);sort(b.c+1,b.c+4);xxx xx1=zou(a,1999999999);int dep1=dep;dep=0;xxx xx2=zou(b,1999999999);int dep2=dep;dep=0;if(!bj(xx1,xx2)){puts("NO");return 0;}if(dep1>dep2){ans+=dep1-dep2;a=zou(a,dep1-dep2);dep1=dep2;}if(dep1<dep2){ans+=dep2-dep1;b=zou(b,dep2-dep1);dep2=dep1;}int l=0,r=dep1+1;   while(l<r){int mid=(l+r)>>1;if(bj(zou(a,mid),zou(b,mid)))r=mid;else l=mid+1;}puts("YES");printf("%d",ans+2*l);return 0;
}

转载于:https://www.cnblogs.com/lher/p/7138081.html

[9018_1563][bzoj_2144]跳跳棋相关推荐

  1. BZOJ 2144 跳跳棋(神仙建模题,倍增 LCA,二分)【BZOJ修复工程】

    整理的算法模板合集: ACM模板 点我看算法全家桶系列!!! 实际上是一个全新的精炼模板整合计划 题目链接 https://hydro.ac/d/bzoj/p/2144 是 hydro 的 BZOJ ...

  2. [BZOJ2144]国家集训队 跳跳棋

    题目描述 跳跳棋是在一条数轴上进行的.棋子只能摆在整点上.每个点不能摆超过一个棋子. 我们用跳跳棋来做一个简单的游戏:棋盘上有3颗棋子,分别在a,b,c这三个位置.我们要通过最少的跳动把他们的位置移动 ...

  3. [数论系列一]C Looooops,跳跳棋,The Luckiest number,CF906D Power Tower,Minimal Power of Prime,仪仗队,LCMSUM

    文章目录 C Looooops description solution code 跳跳棋 description solution code The Luckiest number descript ...

  4. 洛谷 P1852 [国家集训队] 跳跳棋

    题目描述 跳跳棋是在一条数轴上进行的.棋子只能摆在整点上.每个点不能摆超过一个棋子. 我们用跳跳棋来做一个简单的游戏:棋盘上有3颗棋子,分别在a,b,c这三个位置.我们要通过最少的跳动把他们的位置移动 ...

  5. BZOJ 2144 跳跳棋(LCA+欧几里德+二分答案)

    跳跳棋 问题描述 跳跳棋是在一条数轴上进行的.棋子只能摆在整点上.每个点不能摆超过一个棋子.我们用跳跳棋来做一个简单的游戏:棋盘上有3颗棋子,分别在a,b,c这三个位置.我们要通过最少的跳动把他们的位 ...

  6. 【2011集训队出题】跳跳棋

    [2011集训队出题]跳跳棋 Time Limits: 1000 ms Memory Limits: 128000 KB Description 跳跳棋是在一条数轴上进行的.棋子只能摆在整点上.每个点 ...

  7. P1852 跳跳棋(建模LCA)

    P1852 跳跳棋(建模&LCA) 往外跳有个两个状态,往里跳只能有一个唯一父亲状态. 所以是一个二叉树. 将给定的起始和目标状态 向上找到根,判断是否相等.不相等无解. 否则类似求LCA的思 ...

  8. 跳跳棋(国家集训队,LCA,洛谷P1852,BZOJ[2144])

    文章目录 题目 思路 代码 题目 题目链接 描述 跳跳棋是在一条数轴上进行的.棋子只能摆在整点上.每个点不能摆超过一个棋子.我们用跳跳棋来做一个简单的游戏:棋盘上有333颗棋子,分别在a,b,ca,b ...

  9. 跳跳棋【LCA】【二分】

    >Description 跳跳棋是在一条数轴上进行的.棋子只能摆在整点上.每个点不能摆超过一个棋子. 我们用跳跳棋来做一个简单的游戏:棋盘上有3颗棋子,分别在a,b,c这三个位置.我们要通过最少 ...

  10. 牛牛的跳跳棋(贪心)

    题目描述 牛牛最近在玩一种叫做跳跳棋的游戏,棋盘可以看成是一个一维的线性数组,编号从1到n+1. 一开始牛牛的棋子位于第1个格子,游戏的最终目的是将棋子移动到第n+1个格子. 棋盘1~n的每个格子都有 ...

最新文章

  1. 怎样在SecureCRT的shell里用命令上传下载文件(转)
  2. Spring之高级装配(二)
  3. File类对文件的操作应用
  4. 微信监控机器学习、深度学习训练过程,可视化
  5. 图象关于y轴对称是什么意思_关于新风系统的全热交换到底是什么意思?艾尔文技术解读篇...
  6. android中stagefright和OMXCodec原理分析
  7. php微信退款结果通知,微信支付退款结果通知解密
  8. Java生成随机数的公式
  9. python 模拟登录超星强智系统
  10. Java毕设-商标管理系统
  11. AssertionError: Attempted unscale_ but _scale is None
  12. pat 乙级 1094
  13. Kubernetes详解(四十一)——Secret创建
  14. asterisk 说明
  15. 弹性云服务器---ECS
  16. Unity案例课程 - 涂鸦跳跳 Day 1
  17. 全新java架构技术框架Quarkus实战神仙文档
  18. webpy使用笔记(二) session的使用
  19. 【DSP】CCS5.5安装教程
  20. web安全测试之appscan – “X-Content-Type-Options”头缺失或不安全

热门文章

  1. c 如何调用c语言程序设计,c语言程序设计_函数调用c语言程序设计_函数调用.ppt...
  2. Java 大对象类型的 Hiberante 映射
  3. java线程学习笔记
  4. springboot jvm参数
  5. markdown快速创建表格及内容工具
  6. 多用户文件系统java实现_小师妹学JavaIO之:文件系统和WatchService
  7. oracle索引用不了,oracle使用索引与不使用索引的性能详析
  8. 【渝粤教育】国家开放大学2018年春季 0100-22T程序设计基础 参考试题
  9. mfc中窗口大小适合图片大小
  10. 强化学习进阶【逆强化学习】