在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
每个蛋的功能都是一样的,如果一个蛋碎了,你就不能再把它掉下去。 你知道存在楼层 每次移动,你可以取一个鸡蛋(如果你有完整的鸡蛋)并把它从任一楼层 你的目标是确切地知道 无论
示例 1: 输入:K = 1, N = 2 输出:2 解释: 鸡蛋从 1 楼掉落。如果它碎了,我们肯定知道 F = 0 。 否则,鸡蛋从 2 楼掉落。如果它碎了,我们肯定知道 F = 1 。 如果它没碎,那么我们肯定知道 F = 2 。 因此,在最坏的情况下我们需要移动 2 次以确定 F 是多少。 示例 2: 输入:K = 2, N = 6 输出:3 示例 3: 输入:K = 3, N = 14 输出:4
提示:
转载:思路 根据https://github.com/Shellbye/Shellbye.github.io/issues/42换角度思考得到 dp[k][m] 的含义是k个鸡蛋 移动m次最多能够确定多少楼层 dp[k][m] = dp[k - 1][m - 1] + dp[k][m - 1] + 1 根据递推公式 如果采用k倒着从大到小计算 就可以只存一行的dp[k] 直接原地更新dp[k] 不影响后续计算 只需要O(K)空间复杂度 O(KlogN) 鸡蛋完全够用的时候 就是走LogN步 最差情况是1个鸡蛋走N步 O(KN)
#include <iostream> #include <vector> #include <algorithm> using namespace std; static int x = []() {std::ios::sync_with_stdio(false); cin.tie(0); return 0; }(); class Solution { public: int superEggDrop(int K, int N) { vector<int> dp(K + 1, 0); int m = 0; while (dp[K] < N) {//表示当能够测试的最大楼层数刚好是我们需要的楼层数N时,此时取得m的最小值。 m++; for (int k = K; k > 0; --k) { dp[k] = dp[k - 1] + dp[k] + 1;//逆向遍历,不断更新dp[k],使得dp[k]取最大值(能够测试的最大楼层数) } } return m; } }; int main() { Solution A; cout << A.superEggDrop(3, 14); system("PAUSE"); return 0; }
#include <iostream> #include <vector> using namespace std; class Solution { public: int superEggDrop(int K, int N) { vector<vector<int> > dp(K + 1, vector<int>(N, 0)); int m = 0; while(dp[K][m] < N){ ++m; for(int i = K; i > 0; i--) dp[i][m] = dp[i - 1][m - 1] + dp[i][m - 1] + 1; } return m; } }; int main() { Solution A; cout << A.superEggDrop(1, 2); return 0; }
|
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论