跳跳棋【LCA】【二分】

本文介绍了跳跳棋的游戏规则,并提出了如何判断并计算将棋子从初始位置a, b, c移动到目标位置x, y, z所需的最少跳动次数。通过分析,得出关键在于找到每组状态的根节点,并使用二分查找方法来优化搜索过程。当根节点相同时,表明可以完成任务,并输出最少步数。" 100937224,8387604,解题报告:luoguP3513 - KON-Conspiracy 2-SAT问题,"['2-SAT', '图算法', '竞赛编程', '算法题解', ' Tarjan']
摘要由CSDN通过智能技术生成

>Description
跳跳棋是在一条数轴上进行的。棋子只能摆在整点上。每个点不能摆超过一个棋子。
在这里插入图片描述
我们用跳跳棋来做一个简单的游戏:棋盘上有3颗棋子,分别在a,b,c这三个位置。我们要通过最少的跳动把他们的位置移动成x,y,z。(棋子是没有区别的)

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

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


>Input
第一行包含三个整数,表示当前棋子的位置a b c。(互不相同)
第二行包含三个整数,表示目标位置x y z。(互不相同)

>Output
如果无解,输出一行NO。
如果可以到达,第一行输出YES,第二行输出最少步数。


>Sample Input
1 2 3
0 3 5

>Sample Output
YES
2

20% 输入整数的绝对值均不超过10
40% 输入整数的绝对值均不超过10000
100% 绝对值不超过10^9


>解题思路
题目大意:有一个线性的跳棋,问三个点的状态{ a , b , c {a,b,c} a,b,c}能否到达{ x , y , z x,y,z x,y,z},并且输出最小步数

设{a,b,c}为 S 1 S_1 S1,{x,y,z}为 S 2 S_2 S2
通过手动模拟可以发现,一组数据{a,b,c}, a < b < c a<b<c a<b<c,可以达到三种状态:

  1. b b b a a a的方向跳
  2. b b b c c c的方向跳
  3. b b b近的点往 b b b的方向跳,且当仅当 b − a ≠ c − b b-a≠c-b ba
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值