2022-10-09:我们给出了一个(轴对齐的)二维矩形列表 rectangles 。 对于 rectangle[i] = [x1, y1, x2, y2],其中(x1,y1)是矩形 i 左下角的坐
2022-10-09:我们给出了一个(轴对齐的)二维矩形列表 rectangles 。
对于 rectangle[i] = [x1, y1, x2, y2],其中(x1,y1)是矩形 i 左下角的坐标
(xi1, yi1) 是该矩形 左下角 的坐标, (xi2, yi2) 是该矩形 右上角 的坐标。
计算平面中所有 rectangles 所覆盖的 总面积 。
任何被两个或多个矩形覆盖的区域应只计算 一次 。
返回 总面积 。因为答案可能太大,返回 10^9 + 7 的 模 。
输入:rectangles = [[0,0,2,2],[1,0,2,3],[1,0,3,1]]。
输出:6。
答案2022-10-09:
线段树模板题。一个矩形两个事件。这道题用了树结构,对于rust有点复杂,用了Rc<RefCell>的数据类型。
力扣850上测试,rust语言占用内存最低,go语言占用内存略高于rust,但运行速度最快。
不管怎么说,rust和go都是要优于java的。用java的人们,你们赶紧换语言,java过时了。
java,go,rust运行情况见截图。
代码用rust编写。代码如下:
use std::cell::RefCell;
use std::iter::repeat;
use std::rc::Rc;
impl Solution {
pub fn rectangle_area(rectangles: Vec<Vec<i32>>) -> i32 {
let n = rectangles.len() as i32;
let mut arr: Vec<Vec<i64>> = repeat(repeat(0).take(4).collect())
.take((n << 1) as usize)
.collect();
let mut max: i64 = 0;
for i in 0..n {
// x1 y1 左下角点的坐标
// x2 y2 右上角点的坐标
// 解释一下y1为啥要+1
// 比如y1 = 3, y2 = 7
// 实际的处理的时候,真实的线段认为是闭区间[4,7]的
// 如果不这么处理会有问题
// 比如先在y1 = 3, y2 = 7上,都+1
// 那么此时:
// value: 0 0 1 1 1 1 1 0
// index: 1 2 3 4 5 6 7 8
// 这是不对的!
// 因为线段[3,7]长度是4啊!而在线段树里,是5个1!
// 所以,y1 = 3, y2 = 7
// 我们就是认为是4~7,都+1
// 那么此时:
// value: 0 0 0 1 1 1 1 0
// index: 1 2 3 4 5 6 7 8
// 线段树上,正好4个1,和我们想要的距离是一致的
let x1 = rectangles[i as usize][0];
let y1 = rectangles[i as usize][1] + 1;
let x2 = rectangles[i as usize][2];
let y2 = rectangles[i as usize][3];
arr[i as usize][0] = x1 as i64;
arr[i as usize][1] = y1 as i64;
arr[i as usize][2] = y2 as i64;
arr[i as usize][3] = 1;
arr[(i + n) as usize][0] = x2 as i64;
arr[(i + n) as usize][1] = y1 as i64;
arr[(i + n) as usize][2] = y2 as i64;
arr[(i + n) as usize][3] = -1;
max = get_max(max, y2 as i64);
}
return cover_area(&mut arr, n << 1, max);
}
}
fn get_max<T: Clone + Copy + std::cmp::PartialOrd>(a: T, b: T) -> T {
if a > b {
a
} else {
b
}
}
fn cover_area(arr: &mut Vec<Vec<i64>>, n: i32, max: i64) -> i32 {
// 所有的事件,都在arr里
// [x, y1, y2, +1/-1]
// 早 -> 晚
//Arrays.sort(arr, 0, n, (a, b) -> a[0] <= b[0] ? -1 : 1);
arr[0..n as usize].sort_by(|a, b| {
if a[0] < b[0] {
std::cmp::Ordering::Less
} else {
std::cmp::Ordering::Greater
}
});
// max y的值,可能的最大值,非常大也支持!
let mut dst = DynamicSegmentTree::new(max);
let mut pre_x: i64 = 0;
let mut ans: i64 = 0;
for i in 0..n {
// dst.query() : 开点线段树告诉你!y方向真实的长度!
ans += dst.query() * (arr[i as usize][0] - pre_x);
ans %= 1000000007;
pre_x = arr[i as usize][0];
dst.add(arr[i as usize][1], arr[i as usize][2], arr[i as usize][3]);
}
return ans as i32;
}
struct Node {
cover: i64,
len: i64,
left: Option<Rc<RefCell<Node>>>,
right: Option<Rc<RefCell<Node>>>,
}
impl Node {
fn new() -> Self {
Self {
cover: 0,
len: 0,
left: Option::None,
right: Option::None,
}
}
}
struct DynamicSegmentTree {
root: Rc<RefCell<Node>>,
size: i64,
}
impl DynamicSegmentTree {
fn new(max: i64) -> Self {
Self {
root: Rc::new(RefCell::new(Node::new())),
size: max,
}
}
pub fn add(&mut self, ll: i64, rr: i64, cover: i64) {
self.add0(Rc::clone(&self.root), 1, self.size, ll, rr, cover);
}
fn add0(&mut self, cur: Rc<RefCell<Node>>, l: i64, r: i64, ll: i64, rr: i64, cover: i64) {
if ll <= l && rr >= r {
cur.as_ref().borrow_mut().cover += cover;
} else {
if cur.as_ref().borrow().left.is_none() {
cur.as_ref().borrow_mut().left = Some(Rc::new(RefCell::new(Node::new())));
}
if cur.as_ref().borrow().right.is_none() {
cur.as_ref().borrow_mut().right = Some(Rc::new(RefCell::new(Node::new())));
}
let m: i64 = l + ((r - l) >> 1);
if ll <= m {
self.add0(
Rc::clone(&cur.as_ref().borrow().left.as_ref().unwrap()),
l,
m,
ll,
rr,
cover,
);
}
if rr > m {
self.add0(
Rc::clone(&cur.as_ref().borrow().right.as_ref().unwrap()),
m + 1,
r,
ll,
rr,
cover,
);
}
}
self.push_up(cur, l, r);
}
fn push_up(&mut self, cur: Rc<RefCell<Node>>, l: i64, r: i64) {
if cur.as_ref().borrow().cover > 0 {
cur.as_ref().borrow_mut().len = r - l + 1;
} else {
cur.as_ref().borrow_mut().len = if !cur.as_ref().borrow().left.is_none() {
cur.as_ref()
.borrow_mut()
.left
.as_mut()
.unwrap()
.as_ref()
.borrow()
.len
} else {
0
} + if !cur.as_ref().borrow().right.is_none() {
cur.as_ref()
.borrow_mut()
.right
.as_mut()
.unwrap()
.as_ref()
.borrow()
.len
} else {
0
};
}
}
pub fn query(&mut self) -> i64 {
return self.root.as_ref().borrow().len;
}
}
fn main() {
let rectangles = vec![vec![0, 0, 2, 2], vec![1, 0, 2, 3], vec![1, 0, 3, 1]];
let ans = Solution::rectangle_area(rectangles);
println!("ans = {:?}", ans);
}
struct Solution {}
执行结果如下:


2022-10-09:我们给出了一个(轴对齐的)二维矩形列表 rectangles 。 对于 rectangle[i] = [x1, y1, x2, y2],其中(x1,y1)是矩形 i 左下角的坐的更多相关文章
- 用Python+qrcode库创建一个包含信息的二维码
安装qrcode库和PIL库 在命令行中分别输入pip install qrcode 和pip install pillow 导入库格式如下: import PIL import qrcode 下面以 ...
- 一个不错的PHP二维数组排序函数简单易用存用
一个不错的PHP二维数组排序函数简单易用存用 传入数组,传入排序的键,传入排序顺序 public function array_sort($arr,$keys,$type='asc') { $keys ...
- 旋转图像 给定一个 n × n 的二维矩阵表示一个图像。
给定一个 n × n 的二维矩阵表示一个图像. 将图像顺时针旋转 90 度. 说明: 你必须在原地旋转图像,这意味着你需要直接修改输入的二维矩阵.请不要使用另一个矩阵来旋转图像. 示例 : 给定 ma ...
- 小程序踩过的一个小坑---解析二维码decodeURIComponent() url解码
因为我们需要用户扫码进入小程序,每一个货柜都有一个对应的二维码,当然每个二维码里的信息也不一样.用户扫码进入小程序之后,二维码的信息会以参数q带进去,而我们只能在onLoad事件中拿到这个参数, 但是 ...
- Anaconda+django写出第一个web app(二)
今天开始建立App中的第一个Model,命名为Tutorial. Model的定义在main文件夹下的models.py中通过类进行,我们希望Tutorial这个model包含三个属性:标题.内容和发 ...
- 存在一个足够大的二维数组,每个数组中的值都是整数,使用javascript如何实现按每个数组中的平均值,从大到小排序这个二维数组?
这是牛客网上的一道题~ 题意:对数组排序,顺序是按照数组的平均值,即按照一个元素和平均值相减的绝对值的大小来排序...本例按这个绝对值递增排序 解题思想:先求出这个数组的平均值,如果 a<b,那 ...
- 一个for循环打印二维数组
#include<stdio.h> #define MAXX 2 #define MAXY 3 void printarray() { ,,,,,}; ;i< MAXX*MAXY;i ...
- 一个有用的排序函数,array_multisort(),下面的一个用法是根据二维数组里的一个字段值的大小,对该二维数组进行重新排序
从二维数组$cashes中取出一列 'store_id'(二维数组中的每个一维数组都有的字段),按照这个的大小排序,对二维数组$caches里面的一维数组进行重新排序 实际应用如下 想让相同部门的排在 ...
- poj2155一个二维树状数组
...
- 我写的一个Qt 显示二维码( QR Code)的控件(可以去掉对 libpthread 的依赖,而且编译出的库文件可以在 vc2010 的release 模式下使用)
最近一个项目需要显示二维码,所以花了点时间(只用了一个晚上,写的很不完善),写了个显示二维码的控件.当然这个控件用到了些开源的代码,比如qrencode,所以我也打算把我的代码开源. 我的代码参考了 ...
随机推荐
- win10开启休眠
powercfg /hibernate on 管理员模式下的命令提示符
- Java-http请求工具-OkHttp用法
前言:一般Java项目后端发送请求都使用http,最近项目里面大佬建议把http都改成okhttp3(OkHttpClient).故今日记录部分常用发送方式. 代码:为了便于以后使用,这里封装一个Ok ...
- Javaweb学习笔记第十弹
本章存在的意义,大概就是为了回顾一下被遗忘不久的html了 HTML:超文本标记语言(不区分大小写,语法较为松散,但建议书写时规范一些) HTML标签由浏览器来解析 标签展示图片 具体详情也可以去参考 ...
- 如何在 Apinto 实现 HTTP 与gRPC 的协议转换 (上)
什么是 gRPC 像gRPC是由google开发的一个高性能.通用的开源 RPC 框架,主要面向移动应用开发且基于HTTP/2协议标准而设计,同时支持大多数流行的编程语言. gRPC基于 HTTP/2 ...
- 从源码彻底理解 Prometheus/VictoriaMetrics 中的 relabel_configs/metric_relabel_configs 配置
背景 最近接手维护了公司的指标监控系统,之后踩到坑就没站起来过.. 本次问题的起因是我们配置了一些指标的删除策略没有生效: - action: drop_metrics regex: "^e ...
- Sound Joy连接非华为手机热点
很简单,准备两个手机.常用手机和备用手机1.常用手机开启热点2.备用手机连接常用手机的热点,并且已经安装华为智慧生活app3.备用手机连接到常用手机热点后,再打开智慧生活app连接常用手机热点即可
- DIYAUDIO LM3886空板、套件、成品机DIY
diyaudio 3886空板,3886纯后级功放板.最后三张图为成品板子演示图.正确安装后,没有底噪.大水塘电容直径最大35MM.本人已经用这快板子制作了多台成品机,用过的都说好!空板20元,全部1 ...
- 安装Windows10后电脑整体速度变慢
是不是觉得从旧版本Windows系统比如(Windows 7)升级到Windows10以后,感觉什么操作都变慢了.譬如打开文件夹,游戏加载速度变缓慢.尤其是腾讯WeGame软件进入游戏前的检测速度明显 ...
- 原型继承和 Class 继承
涉及面试题: 原型如何实现继承? Class 如何实现继承? Class 本质是什么? ⾸先先来讲下 class ,其实在 JS 中并不存在类, class 只是语法糖,本质还是函数. class P ...
- 最新版本 Stable Diffusion 开源AI绘画工具之部署篇
目录 AI绘画 本地环境要求 下载 Stable Diffusion 运行启动 AI绘画 关于 AI 绘画最近有多火,既然你有缘能看到这篇文章,那么相信也不需要我过多赘述了吧? 随着 AI 绘画技术的 ...