即把前n-1个盘子从A柱移到B柱,然后把A柱上剩的那一个盘子移动到C柱,最后把B柱上的那n-1个盘子移动到C柱上
初始化:f[1] = 1(一个盘子在4塔模式下移动到D柱需要1步)
先把i个盘子在4塔模式下移动到B柱,
然后把n-i个盘子在3塔模式下移动到D柱(因为不能覆盖到B柱上,就等于只剩下A、C、D柱可以用)
最后把i个盘子在4塔模式下移动到D柱
考虑所有可能的i取最小值,即得到上述递推公式
- #include
- #include
- #include
- using namespace std;
- int d[10000], f[10000];
- int main() {
- int n;
- cin >> n;
- d[1] = 1;
- for (int i = 2; i <= n; i++)
- d[i] = 2 * d[i - 1] + 1;
- memset(f, 0x3f3f3f3f, sizeof(f));
- f[1] = 1;
- for (int i = 2; i <= n; i++)
- for (int j = 1; j < i; j++)
- f[i] = min(f[i], 2 * f[j] + d[i - j]);
- for (int i = 1; i <= n; i++)
- cout << f[i] << endl;
- return 0;
- }