传送门:https://atcoder.jp/contests/abc188/tasks/abc188_f
题意
在只能在+1-1和*2三种操作的情况下,如果将X变为Y?
思路
因为每次操作都会经过三次选择,是+1呢还是-1呢还是*2呢?
因为这个转移是从后往前转移,所以是将Y如何变为X即可,只不过*2变为/2而已。
所以有一下转移方案:$()^{-1}$表示逆过程
在转移到为n时
- 当n<=x时,$return \;\;n-x((-1)^{-1}$转移)
- 当n为任意数时,$return \;\;x-n((+1)^{-1}$转移)
- 当n为偶数时,$return \;\;DFS(n / 2)+1((*2)^{-1}$转移)
- 当n为奇数时,$return \;\;DFS((n-1) / 2)+2(+1*2)^{-1}$转移
- 当n为奇数时,$return \;\;DFS((n+1)/2)+2(-1*2)^{-1}$转移 最后取min即可。
看到上面有很多状态转移,所以我们可以在DFS过程中记忆化。
Code
1 | ##include <bits/stdc++.h> |
本文作者:jujimeizuo
本文地址: https://blog.jujimeizuo.cn/2021/01/14/atcoder-beginner-contest-188-f/
本博客所有文章除特别声明外,均采用 CC BY-SA 3.0 协议。转载请注明出处!