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

本文介绍了跳跳棋游戏的规则,并详细分析了解决问题的思路,包括如何判断游戏是否可达以及如何找到最小步数。通过转换棋子位置状态,利用最短路径算法(如LCA)来确定最少的跳动次数。最后,提供了问题的代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

文章目录

题目

题目链接
描述
跳跳棋是在一条数轴上进行的。棋子只能摆在整点上。每个点不能摆超过一个棋子。我们用跳跳棋来做一个简单的游戏:棋盘上有 3 3 3颗棋子,分别在 a , b , c a,b,c abc这三个位置。我们要通过最少的跳动把他们的位置移动成 x , y , z x,y,z xyz。(棋子是没有区别的)跳动的规则很简单,任意选一颗棋子,对一颗中轴棋子跳动。跳动两颗棋子距离不变。一次只允许跳过 1 1 1颗棋子。
在这里插入图片描述

写一个程序,首先判断是否可以完成任务。如果可以,输出最少需要的跳动次数。
输入
第一行包含三个整数,表示当前棋子的位置 a b c a b c abc。(互不相同)
第二行包含三个整数,表示目标位置 x y z x y z xyz。(互不相同)
输出
如果无解,输出一行NO。如果可以到达,第一行输出YES,第二行输出最少步数。
样例输入
1 2 3
0 3 5
样例输出
YES
2
范围
100 % 100\% 100% 绝对值不超过 1 0 9 10^9 109

思路

设有a,b,c三点,且 a ≤ b ≤ c a\leq b \leq c abc
则有两种方式跳
一、b跳
则只有两种状态 ( 2 a − b , a , c ) (2a-b,a,c) 2abac ( a , c , 2 c − b ) (a,c,2c-b) ac2cb,可看做无限扩展
二、a,c绕着b跳,则有一下三种情况:
我们设 d 1 = b − a , d 2 = c − b d_1 = b-a,d_2 = c-b d1=bad2=cb
1、 d 1 > d 2

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值