【算法学习】扫描线

news/2025/1/12 19:57:08/文章来源:https://www.cnblogs.com/sadlin/p/18520882

这篇题解写的难以言喻,可能只有我能看的懂!

前言

虽然我觉得这个算法目前不太可能会考,但是我觉得挺有意思的,而且学个算法也挺好,我是为自己学的!!!

定义

扫描线可以求二维图形的面积,也可以求周长等多种用途……

P5490 【模板】扫描线 & 矩形面积并

这就是扫描线的模板题,我们有这么一个图形我们按照他的端点划分成许多个线段。

这个概括动图了扫描线的全过程。

我们将端点划分成线段,将线段抽象线段树的节点,我们用线段树维护线段的出现次数和线段长度

这个概括了扫描线的全过程

然后我们将读入的矩阵下线段标为1,上线段标为-1,我们这一个节点(线段)的出现次数为0时是不能统计答案的。

bool cmp(ss g,ss h){return g.h<h.h;
}
for(int i=1;i<=n;i++){int x,y,xx,yy;cin>>x>>y>>xx>>yy;dc[i*2-1]=x;dc[i*2]=xx;a[i*2-1]={x,xx,y,1};a[i*2]={x,xx,yy,-1};
}
sort(a+1,a+n+1,cmp);
sort(dc+1,dc+n+1);
int tot=unique(dc+1,dc+n+1)-dc-1;

我们按照高度排序是为了计算高度来计算面积,坐标都很大,我们需要离散化一下来缩小范围。

int ans=0;
for(int i=1;i<n;i++){change(1,1,tot-1,a[i].l,a[i].r,a[i].mark);ans+=len[1]*(a[i+1].h-a[i].h);
}
cout<<ans;

然后对于新来的线段我们要我们要更新目前整个线对应到矩阵上的长度,然后再对高度计算答案。

void pushup(int p,int l,int r){if(sum[p]){len[p]=dc[r+1]-dc[l];}else{len[p]=len[ls]+len[rs];}
}void change(int p,int pl,int pr,int l,int r,int c){if(dc[pl]>=r||dc[pr+1]<=l){return;}if(l<=dc[pl]&&dc[pr+1]<=r){sum[p]+=c;pushup(p,pl,pr);return;}int mid=(pl+pr)>>1;change(ls,pl,mid,l,r,c);change(rs,mid+1,pr,l,r,c);pushup(p,pl,pr);
}

我们选择用左端点来对应这条线段,右端点也要参与计算进来。这里我们通过更新我们线扫到的长度。

然后就可以了,我全篇不知道在讲什么,就这样吧不管了。

极速版:

#include <bits/stdc++.h>
#define int long long
#define ls p<<1
#define rs p<<1|1 
#define fi first
#define se second
#define re register 
#define pir pair<int,int>
const int inf=1e9;
const int mod=998244353;
const int N=1e6+10;
using namespace std;int n;int dc[N];struct ss{int l,r,h,mark;
}a[N];bool cmp(ss g,ss h){return g.h<h.h;
}int sum[N<<2];
int len[N<<2];void pushup(int p,int l,int r){if(sum[p]){len[p]=dc[r+1]-dc[l];}else{len[p]=len[ls]+len[rs];}
}void change(int p,int pl,int pr,int l,int r,int c){if(dc[pl]>=r||dc[pr+1]<=l){return;} if(l<=dc[pl]&&dc[pr+1]<=r){sum[p]+=c;pushup(p,pl,pr);return;}int mid=(pl+pr)>>1;change(ls,pl,mid,l,r,c);change(rs,mid+1,pr,l,r,c);pushup(p,pl,pr); 
}signed main(){ios::sync_with_stdio(false);cin.tie(nullptr); cin>>n;for(int i=1;i<=n;i++){int x,y,xx,yy;cin>>x>>y>>xx>>yy;dc[i*2-1]=x;dc[i*2]=xx;a[i*2-1]={x,xx,y,1};a[i*2]={x,xx,yy,-1};}n<<=1;sort(a+1,a+n+1,cmp);sort(dc+1,dc+n+1);int tot=unique(dc+1,dc+n+1)-dc-1;int ans=0;for(int i=1;i<n;i++){change(1,1,tot-1,a[i].l,a[i].r,a[i].mark);ans+=len[1]*(a[i+1].h-a[i].h);}cout<<ans;return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/825328.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

leetcode 740 删除并获得点数

740 删除并获得点数 题意 给你一个整数数组 nums ,你可以对它进行一些操作。 每次操作中,选择任意一个 nums[i] ,删除它并获得 nums[i] 的点数。之后,你必须删除 所有 等于 nums[i] - 1 和 nums[i] + 1 的元素。 开始你拥有 0 个点数。返回你能通过这些操作获得的最大点数。…

Navicat 17下载与安装

1、安装包 Navicat 17: 链接:https://pan.quark.cn/s/c75e892c4705 提取码:YvyF Navicat 16: 链接:https://pan.quark.cn/s/63c07b20ea7b提取码:B9ij 2、安装教程(这里以安装Navicat 17 为例) 1) 如之前已安装的需卸载当前Navicat,如未安装,直接双击无限试用…

gitlab怎么保护分支

​GitLab作为一个流行的版本控制工具其中“分支保护”是一个关键功能,用以防止开发过程中的不当操作对代码造成不可逆的影响。本文将指导你如何在GitLab中保护分支:1.理解保护分支的重要性;2.学会使用GitLab的界面进行分支的保护操作;3.了解与合并请求的关联使用;4.探讨在…

[编程笔记] 搞人心态的代码含毒事件 “svn无法成功完成操作因为文件包含病毒或潜在的垃圾软件”

svn无法成功完成操作因为文件包含病毒或潜在的垃圾软件,Windows Defender误判?今天突然冒出来的问题,烦死了!     svn拉取代码报毒了,不用想,基本就是下面几个可能性:1、某人提交的代码有毒2、电脑上的第三方杀毒软件引发3、Windows Defender误判报毒的代码是一个dl…

AI作文批阅,AI素材管理……璞华集团携多款明星产品亮相智能社会治理论坛

2024年10月25日,金秋十月的璀璨时节,备受瞩目的第二届智能社会治理论坛暨中国光谷人工智能艺术大会在中国光谷盛大启幕。此次论坛汇聚了人工智能领域的顶尖智慧,共同探讨人工智能技术的最新突破与智能社会治理模式的创新路径,同时强调了科技与文化融合的无限可能。璞华集团…

有Redis为什么还要本地缓存?谈谈你对本地缓存的理解?

本地缓存是将数据存储在应用程序所在的本地内存中的缓存方式。既然,已经有了 Redis 可以实现分布式缓存了,为什么还需要本地缓存呢?接下来,我们一起来看。 为什么需要本地缓存? 尽管已经有 Redis 缓存了,但本地缓存也是非常有必要的,因为它有以下优点:速度优势:本地缓…

Adobe After Effects各版本安装包下载与安装

1、安装包我用夸克网盘分享了 After Effects 2024: 链接:https://pan.quark.cn/s/fac88adbac44 提取码:9ZMW After Effects 2023: 链接:https://pan.quark.cn/s/d41a0a447b93 提取码:4pwM After Effects 2022: 链接:https://pan.quark.cn/s/0070a59da58d 提取码:Eij1 Af…

Adobe InDesign 各版本下载与安装

1、安装包我用夸克网盘分享了「Adobe InDesign 2023.rar」,点击链接即可保存。打开「夸克APP」,无需下载在线播放视频,畅享原画5倍速,支持电视投屏。 链接:https://pan.quark.cn/s/526c259dad6f 提取码:MfMXAdobe InDesign 2022: 链接:https://pan.quark.cn/s/c7ee80a21…

井底车场人员进入识别智慧矿山一体机人车防碰撞识别:矿山AI识别算法是如何训练的?

智慧矿山一体机是为矿山环境量身定制的智能设备,其核心任务是预防和减少重大安全风险,并充分利用边缘计算的视频智能识别技术。该设备能够提供包括安全监控、设备状态监测和灾害预警在内的多种智能化功能,完全满足矿山场景视频智能化建设的技术规范和验收标准。训练矿山视频…

Adobe Premiere pro 2022/2021/2020/2019/2018/2015 cc下载与安装

1、安装包下载Adobe Premiere pro 2022: 链接:https://pan.quark.cn/s/33db77cfb56b 提取码:7dbHAdobe Premiere pro 中文破解版: 链接:https://pan.quark.cn/s/c81bfd04e2aa 提取码:tNk1Adobe Premiere pro 2020 绿色精简: 链接:https://pan.quark.cn/s/69496dcc7351 …

Adobe Photoshop 2021下载与安装

1、安装包2021 Photoshop 2021 cc 免安装绿色中文版: 链接:https://pan.quark.cn/s/d32465740151 提取码:Ln9jPhotoshop 2021 cc 中文完整版: 链接:https://pan.quark.cn/s/daf54ca61e53 提取码:MF6UAdobe photoshop cc 2019中文完整版免激活: 链接:https://pan.quark.…

【原理】Redis热点Key自动发现机制和客户端缓存方案

作者:京东物流 京东物流 本文详细讲解下Redis热点key发现机制+客户端缓存的原理。 一、redis4.0之基于LFU的热点key发现机制 业务中存在访问热点是在所难免的,然而如何发现热点key一直困扰着许多用户,redis4.0为我们带来了许多新特性,其中便包括基于LFU的热点key发现机制。…