2022-10-07:给定员工的 schedule 列表,表示每个员工的工作时间。 每个员工都有一个非重叠的时间段 Intervals 列表,这些时间段已经排好序。 返回表示 所有 员工的 共同,正
2022-10-07:给定员工的 schedule 列表,表示每个员工的工作时间。
每个员工都有一个非重叠的时间段 Intervals 列表,这些时间段已经排好序。
返回表示 所有 员工的 共同,正数长度的空闲时间 的有限时间段的列表,同样需要排好序。
输入:schedule = [[[1,3],[6,7]],[[2,4]],[[2,5],[9,12]]]。
输出:[[5,6],[7,9]]。
答案2022-10-07:
哈希表+排序。扫描线算法。
代码用rust编写。代码如下:
use std::collections::HashSet;
fn main() {
let mut schedule = vec![
vec![Interval::new(1, 3), Interval::new(6, 7)],
vec![Interval::new(2, 4)],
vec![Interval::new(2, 5), Interval::new(9, 12)],
];
let ans = employee_free_time(&mut schedule);
println!("ans = {:?}", ans);
}
#[derive(Debug)]
struct Interval {
start: i32,
end: i32,
}
impl Interval {
fn new(s: i32, e: i32) -> Self {
Self { start: s, end: e }
}
}
// 哈希表!
fn employee_free_time(schedule: &mut Vec<Vec<Interval>>) -> Vec<Interval> {
let mut arr: Vec<Vec<i32>> = vec![];
for people in schedule.iter() {
for interval in people.iter() {
// 0 开始时间点,有个员工要上线
// 1 结束时间点,有个员工要下线
arr.push(vec![interval.start, interval.end, 0]);
arr.push(vec![interval.end, interval.end, 1]);
}
}
arr.sort_by(|a, b| a[0].cmp(&b[0]));
let mut set: HashSet<i32> = HashSet::new();
set.insert(arr[0][1]);
let mut ans: Vec<Interval> = vec![];
for i in 1..arr.len() as i32 {
//int[] cur = arr.get(i);
if arr[i as usize][2] == 0 {
// 开始时间点来到的时候,来看看有没有空闲时间段
// 3 7
if set.len() == 0 && arr[(i - 1) as usize][0] != arr[i as usize][0] {
ans.push(Interval::new(arr[(i - 1) as usize][0], arr[i as usize][0]));
}
// 哈希表填人了,cur[1]
set.insert(arr[i as usize][1]);
} else {
set.remove(&arr[i as usize][0]);
}
}
return ans;
}
执行结果如下:
公众号:福大大架构师每日一题
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
2021-10-07 2021-10-07:将有序数组转换为二叉搜索树。给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵 高度平衡 二叉搜索树。高度平衡 二叉树是一棵满足「每个节点的左右两个子树
2020-10-07 2020-10-07:redis存在线程安全的问题吗?为什么?