你被安排了 n
个任务。任务需要花费的时间用长度为 n
的整数数组 tasks
表示,第 i
个任务需要花费 tasks[i]
小时完成。一个 工作时间段 中,你可以 至多 连续工作 sessionTime
个小时,然后休息一会儿。
你需要按照如下条件完成给定任务:
- 如果你在某一个时间段开始一个任务,你需要在 同一个 时间段完成它。
- 完成一个任务后,你可以 立马 开始一个新的任务。
- 你可以按 任意顺序 完成任务。
给你 tasks
和 sessionTime
,请你按照上述要求,返回完成所有任务所需要的 最少 数目的 工作时间段 。
测试数据保证 sessionTime
大于等于 tasks[i]
中的 最大值 。
示例 1:
输入:tasks = [1,2,3], sessionTime = 3 输出:2 解释:你可以在两个工作时间段内完成所有任务。 - 第一个工作时间段:完成第一和第二个任务,花费 1 + 2 = 3 小时。 - 第二个工作时间段:完成第三个任务,花费 3 小时。
示例 2:
输入:tasks = [3,1,3,1,1], sessionTime = 8 输出:2 解释:你可以在两个工作时间段内完成所有任务。 - 第一个工作时间段:完成除了最后一个任务以外的所有任务,花费 3 + 1 + 3 + 1 = 8 小时。 - 第二个工作时间段,完成最后一个任务,花费 1 小时。
示例 3:
输入:tasks = [1,2,3,4,5], sessionTime = 15 输出:1 解释:你可以在一个工作时间段以内完成所有任务。
提示:
n == tasks.length
1 <= n <= 14
1 <= tasks[i] <= 10
max(tasks[i]) <= sessionTime <= 15
我们注意到
我们用一个长度为
我们可以枚举
最终的答案即为
时间复杂度
class Solution:
def minSessions(self, tasks: List[int], sessionTime: int) -> int:
n = len(tasks)
ok = [False] * (1 << n)
for i in range(1, 1 << n):
t = sum(tasks[j] for j in range(n) if i >> j & 1)
ok[i] = t <= sessionTime
f = [inf] * (1 << n)
f[0] = 0
for i in range(1, 1 << n):
j = i
while j:
if ok[j]:
f[i] = min(f[i], f[i ^ j] + 1)
j = (j - 1) & i
return f[-1]
class Solution {
public int minSessions(int[] tasks, int sessionTime) {
int n = tasks.length;
boolean[] ok = new boolean[1 << n];
for (int i = 1; i < 1 << n; ++i) {
int t = 0;
for (int j = 0; j < n; ++j) {
if ((i >> j & 1) == 1) {
t += tasks[j];
}
}
ok[i] = t <= sessionTime;
}
int[] f = new int[1 << n];
Arrays.fill(f, 1 << 30);
f[0] = 0;
for (int i = 1; i < 1 << n; ++i) {
for (int j = i; j > 0; j = (j - 1) & i) {
if (ok[j]) {
f[i] = Math.min(f[i], f[i ^ j] + 1);
}
}
}
return f[(1 << n) - 1];
}
}
class Solution {
public:
int minSessions(vector<int>& tasks, int sessionTime) {
int n = tasks.size();
bool ok[1 << n];
memset(ok, false, sizeof(ok));
for (int i = 1; i < 1 << n; ++i) {
int t = 0;
for (int j = 0; j < n; ++j) {
if (i >> j & 1) {
t += tasks[j];
}
}
ok[i] = t <= sessionTime;
}
int f[1 << n];
memset(f, 0x3f, sizeof(f));
f[0] = 0;
for (int i = 1; i < 1 << n; ++i) {
for (int j = i; j; j = (j - 1) & i) {
if (ok[j]) {
f[i] = min(f[i], f[i ^ j] + 1);
}
}
}
return f[(1 << n) - 1];
}
};
func minSessions(tasks []int, sessionTime int) int {
n := len(tasks)
ok := make([]bool, 1<<n)
f := make([]int, 1<<n)
for i := 1; i < 1<<n; i++ {
t := 0
f[i] = 1 << 30
for j, x := range tasks {
if i>>j&1 == 1 {
t += x
}
}
ok[i] = t <= sessionTime
}
for i := 1; i < 1<<n; i++ {
for j := i; j > 0; j = (j - 1) & i {
if ok[j] {
f[i] = min(f[i], f[i^j]+1)
}
}
}
return f[1<<n-1]
}
function minSessions(tasks: number[], sessionTime: number): number {
const n = tasks.length;
const ok: boolean[] = new Array(1 << n).fill(false);
for (let i = 1; i < 1 << n; ++i) {
let t = 0;
for (let j = 0; j < n; ++j) {
if (((i >> j) & 1) === 1) {
t += tasks[j];
}
}
ok[i] = t <= sessionTime;
}
const f: number[] = new Array(1 << n).fill(1 << 30);
f[0] = 0;
for (let i = 1; i < 1 << n; ++i) {
for (let j = i; j > 0; j = (j - 1) & i) {
if (ok[j]) {
f[i] = Math.min(f[i], f[i ^ j] + 1);
}
}
}
return f[(1 << n) - 1];
}