comments | difficulty | edit_url | tags | |||
---|---|---|---|---|---|---|
true |
困难 |
|
n
个人,按从 0
到 n - 1
编号。现在有一扇门,每个人只能通过门进入或离开一次,耗时一秒。
给你一个 非递减顺序 排列的整数数组 arrival
,数组长度为 n
,其中 arrival[i]
是第 i
个人到达门前的时间。另给你一个长度为 n
的数组 state
,其中 state[i]
是 0
则表示第 i
个人希望进入这扇门,是 1
则表示 TA 想要离开这扇门。
如果 同时 有两个或更多人想要使用这扇门,则必须遵循以下规则:
- 如果前一秒 没有 使用门,那么想要 离开 的人会先离开。
- 如果前一秒使用门 进入 ,那么想要 进入 的人会先进入。
- 如果前一秒使用门 离开 ,那么想要 离开 的人会先离开。
- 如果多个人都想朝同一方向走(都进入或都离开),编号最小的人会先通过门。
返回一个长度为 n
的数组 answer
,其中 answer[i]
是第 i
个人通过门的时刻(秒)。
- 每秒只有一个人可以通过门。
- 为遵循上述规则,一个人可以在到达门附近后等待,而不通过门进入或离开。
示例 1:
输入:arrival = [0,1,1,2,4], state = [0,1,0,0,1] 输出:[0,3,1,2,4] 解释:每秒发生的情况如下: - t = 0 :第 0 个人是唯一一个想要进入的人,所以 TA 可以直接进入。 - t = 1 :第 1 个人想要离开,第 2 个人想要进入。因为前一秒有人使用门进入,所以第 2 个人先进入。 - t = 2 :第 1 个人还是想要离开,第 3 个人想要进入。因为前一秒有人使用门进入,所以第 3 个人先进入。 - t = 3 :第 1 个人是唯一一个想要离开的人,所以 TA 可以直接离开。 - t = 4 :第 4 个人是唯一一个想要进入的人,所以 TA 可以直接离开。
示例 2:
输入:arrival = [0,0,0], state = [1,0,1] 输出:[0,2,1] 解释:每秒发生的情况如下: - t = 0 :第 1 个人想要进入,但是第 0 个人和第 2 个人都想要离开。因为前一秒没有使用门,所以想要离开的人会先离开。又因为第 0 个人的编号更小,所以 TA 先离开。 - t = 1 :第 1 个人想要进入,第 2 个人想要离开。因为前一秒有人使用门离开,所以第 2 个人先离开。 - t = 2 :第 1 个人是唯一一个想要进入的人,所以 TA 可以直接进入。
提示:
n == arrival.length == state.length
1 <= n <= 105
0 <= arrival[i] <= n
arrival
按 非递减顺序 排列state[i]
为0
或1
我们定义两个队列,其中
我们维护一个时间
我们遍历数组
然后我们判断当前队列
接下来,我们将时间
时间复杂度
class Solution:
def timeTaken(self, arrival: List[int], state: List[int]) -> List[int]:
q = [deque(), deque()]
n = len(arrival)
t = i = 0
st = 1
ans = [0] * n
while i < n or q[0] or q[1]:
while i < n and arrival[i] <= t:
q[state[i]].append(i)
i += 1
if q[0] and q[1]:
ans[q[st].popleft()] = t
elif q[0] or q[1]:
st = 0 if q[0] else 1
ans[q[st].popleft()] = t
else:
st = 1
t += 1
return ans
class Solution {
public int[] timeTaken(int[] arrival, int[] state) {
Deque<Integer>[] q = new Deque[2];
Arrays.setAll(q, i -> new ArrayDeque<>());
int n = arrival.length;
int t = 0, i = 0, st = 1;
int[] ans = new int[n];
while (i < n || !q[0].isEmpty() || !q[1].isEmpty()) {
while (i < n && arrival[i] <= t) {
q[state[i]].add(i++);
}
if (!q[0].isEmpty() && !q[1].isEmpty()) {
ans[q[st].poll()] = t;
} else if (!q[0].isEmpty() || !q[1].isEmpty()) {
st = q[0].isEmpty() ? 1 : 0;
ans[q[st].poll()] = t;
} else {
st = 1;
}
++t;
}
return ans;
}
}
class Solution {
public:
vector<int> timeTaken(vector<int>& arrival, vector<int>& state) {
int n = arrival.size();
queue<int> q[2];
int t = 0, i = 0, st = 1;
vector<int> ans(n);
while (i < n || !q[0].empty() || !q[1].empty()) {
while (i < n && arrival[i] <= t) {
q[state[i]].push(i++);
}
if (!q[0].empty() && !q[1].empty()) {
ans[q[st].front()] = t;
q[st].pop();
} else if (!q[0].empty() || !q[1].empty()) {
st = q[0].empty() ? 1 : 0;
ans[q[st].front()] = t;
q[st].pop();
} else {
st = 1;
}
++t;
}
return ans;
}
};
func timeTaken(arrival []int, state []int) []int {
n := len(arrival)
q := [2][]int{}
t, i, st := 0, 0, 1
ans := make([]int, n)
for i < n || len(q[0]) > 0 || len(q[1]) > 0 {
for i < n && arrival[i] <= t {
q[state[i]] = append(q[state[i]], i)
i++
}
if len(q[0]) > 0 && len(q[1]) > 0 {
ans[q[st][0]] = t
q[st] = q[st][1:]
} else if len(q[0]) > 0 || len(q[1]) > 0 {
if len(q[0]) == 0 {
st = 1
} else {
st = 0
}
ans[q[st][0]] = t
q[st] = q[st][1:]
} else {
st = 1
}
t++
}
return ans
}
function timeTaken(arrival: number[], state: number[]): number[] {
const n = arrival.length;
const q: number[][] = [[], []];
let [t, i, st] = [0, 0, 1];
const ans: number[] = Array(n).fill(0);
while (i < n || q[0].length || q[1].length) {
while (i < n && arrival[i] <= t) {
q[state[i]].push(i++);
}
if (q[0].length && q[1].length) {
ans[q[st][0]] = t;
q[st].shift();
} else if (q[0].length || q[1].length) {
st = q[0].length ? 0 : 1;
ans[q[st][0]] = t;
q[st].shift();
} else {
st = 1;
}
t++;
}
return ans;
}
use std::collections::VecDeque;
impl Solution {
pub fn time_taken(arrival: Vec<i32>, state: Vec<i32>) -> Vec<i32> {
let n = arrival.len();
let mut q = vec![VecDeque::new(), VecDeque::new()];
let mut t = 0;
let mut i = 0;
let mut st = 1;
let mut ans = vec![-1; n];
while i < n || !q[0].is_empty() || !q[1].is_empty() {
while i < n && arrival[i] <= t {
q[state[i] as usize].push_back(i);
i += 1;
}
if !q[0].is_empty() && !q[1].is_empty() {
ans[*q[st].front().unwrap()] = t;
q[st].pop_front();
} else if !q[0].is_empty() || !q[1].is_empty() {
st = if q[0].is_empty() { 1 } else { 0 };
ans[*q[st].front().unwrap()] = t;
q[st].pop_front();
} else {
st = 1;
}
t += 1;
}
ans
}
}