-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathProblem_2560_minCapability.cc
67 lines (62 loc) · 1.48 KB
/
Problem_2560_minCapability.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#include <algorithm>
#include <vector>
#include "UnitTest.h"
using namespace std;
// @sa https://www.bilibili.com/video/BV1pw411M7Du/
class Solution
{
public:
int minCapability(vector<int>& nums, int k)
{
int left = *min_element(nums.begin(), nums.end());
int right = *max_element(nums.begin(), nums.end());
while (left < right)
{
// 尝试最小的偷钱能力
int mid = (right - left) / 2 + left;
// visited 用于限制相邻的不能同时偷
bool visited = false;
int count = 0;
// 早抢就抢的策略? 不用动态规划,这里对吗?
// 对,因为这里求的不是累加和,而是房间数,每次都只加1
// 早抢就抢,能给后面预留的空间更大,房间数的可能也更大
for (int x : nums)
{
if (x <= mid && !visited)
{
// 计算当前的偷钱能力能覆盖多少个房间
count++;
visited = true;
}
else
{
visited = false;
}
}
if (count >= k)
{
// 符合条件,右窗口不断左移,尽量取最小的偷钱能力
right = mid;
}
else
{
left = mid + 1;
}
}
return right;
}
};
void test()
{
Solution s;
vector<int> n1 = {2, 3, 5, 9};
vector<int> n2 = {2, 7, 9, 3, 1};
EXPECT_EQ_INT(5, s.minCapability(n1, 2));
EXPECT_EQ_INT(2, s.minCapability(n2, 2));
EXPECT_SUMMARY;
}
int main()
{
test();
return 0;
}