uva11983扫描线k次覆盖
自己做的是从下往上扫描的,一直wa,不知道坑在哪里。。但是作为模板。我还是找了份不错的ac代码
/*
被覆盖不低于k次的点
每个点对应了一个单位面积,本题把点转面积即是被覆盖不低于k次的面积
可以当做求k次面积覆盖模板的题目!
*/
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<map>
using namespace std;
#define maxn 60005
#define lson l,m,rt<<1
#define rson m,r,rt<<1|1
#define ll long long
int n,k;
struct Seg{
int l,r,h,c;
Seg(){}
Seg(int l,int r,int h,int c):l(l),r(r),h(h),c(c){}
bool operator<(const Seg& a)const {
return h<a.h;
}
}segs[maxn];
int tot,totx,x[maxn];//线段树建立在x轴上
int len[maxn<<][],flag[maxn<<];
map<int,int>mp; inline void pushup(int rt,int l,int r){
if(flag[rt]>=k){
for(int i=;i<=k;i++) len[rt][i]=;
len[rt][k]=x[r]-x[l]; }
else if(flag[rt]>){
int cur=flag[rt];//当前区间覆盖次数
for(int i=;i<=k;i++) len[rt][i]=;//先把当前区间所有覆盖情况置零
len[rt][cur]=x[r]-x[l];
if(l+==r) return; for(int i=;i<=k;i++){
if(i+cur>=k) len[rt][k]+=len[rt<<][i]+len[rt<<|][i];
else len[rt][i+cur]+=len[rt<<][i]+len[rt<<|][i];
}
for(int i=cur+;i<=k;i++)
len[rt][cur]-=len[rt][i];
}
else {
for(int i=;i<=k;i++) len[rt][i]=;
if(l+==r) return;
for(int i=;i<=k;i++)
len[rt][i]=len[rt<<][i]+len[rt<<|][i];
}
}
void update(int L,int R,int c,int l,int r,int rt){
if(L<=l && R>=r){
flag[rt]+=c;;
pushup(rt,l,r);
return;
}
int m=l+r>>;
if(L<m) update(L,R,c,lson);
if(R>m) update(L,R,c,rson);
pushup(rt,l,r);
} void init(){
tot=totx=;
mp.clear();
memset(len,,sizeof len);
memset(flag,,sizeof flag);
}
int main(){
int T,a,b,c,d;
cin >> T;
for(int tt=;tt<=T;tt++){
init();
scanf("%d%d",&n,&k);
for(int i=;i<n;i++){
scanf("%d%d%d%d",&a,&b,&c,&d);
c++;d++;
segs[tot++]=Seg(a,c,b,);
segs[tot++]=Seg(a,c,d,-);
x[totx++]=a;x[totx++]=c;
}
sort(x,x+totx);
sort(segs,segs+tot);
totx=unique(x,x+totx)-x;
for(int i=;i<totx;i++) mp[x[i]]=i; ll res=;
for(int i=;i<tot;i++){
if(i!=)
res+=(segs[i].h-segs[i-].h)*len[][k];
// cout<<segs[i].h-segs[i-1].h<< " "<<len[1][k]<<'\n';
update(mp[segs[i].l],mp[segs[i].r],segs[i].c,,totx-,); }
printf("Case %d: %lld\n",tt,res);
}
return ;
}
uva11983扫描线k次覆盖的更多相关文章
- HDU 4862 Jump(最小K路径覆盖)
输入一个n×m网格图,每个结点的值为0-9,可以从任意点出发不超过k次,走完每个点且仅访问每个结点一次,问最终的能量最大值.不可全部走完的情况输出-1. 初始能量为0. 而结点(x,y)可以跳跃到结点 ...
- 网络费用流-最小k路径覆盖
多校联赛第一场(hdu4862) Jump Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Ot ...
- UVA-11983-Weird Advertisement(线段树+扫描线)[求矩形覆盖K次以上的面积]
题意: 求矩形覆盖K次以上的面积 分析: k很小,可以开K颗线段树,用sum[rt][i]来保存覆盖i次的区间和,K次以上全算K次 // File Name: 11983.cpp // Author: ...
- Comet OJ 茶颜悦色 线段树+扫描线(矩形覆盖最多点+优化)
题目:https://www.cometoj.com/contest/59/problem/D?problem_id=2713 题意:给你一个正方形,然后给你n个点,这个正方形能随意放哪,要求那个正方 ...
- POJ 2482 扫描线(面积覆盖最大次数)
Stars in Your Window Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 10806 Accepted: ...
- hdu 4862 KM算法 最小K路径覆盖的模型
http://acm.hdu.edu.cn/showproblem.php?pid=4862 选t<=k次,t条路要经过全部的点一次而且只一次. 建图是问题: 我自己最初就把n*m 个点分别放入 ...
- [LeetCode] 632. Smallest Range Covering Elements from K Lists 覆盖K个列表元素的最小区间
You have k lists of sorted integers in ascending order. Find the smallest range that includes at lea ...
- POJ 3261 字符串上的k次覆盖问题
题目大意: 给定一个数组,求一个最大的长度的子串至少出现过k次 一个子串出现多次,也就是说必然存在2个子串间的前缀长度为所求的值 通过二分答案,通过线性扫一遍,去判断出现次数,也就是说每次遇见一个he ...
- poj3680 Intervals 区间k覆盖问题 最小费用最大流 建图巧妙
/** 题目:poj3680 Intervals 区间k覆盖问题 最小费用最大流 建图巧妙 链接:http://poj.org/problem?id=3680 题意:给定n个区间,每个区间(ai,bi ...
随机推荐
- HDU - 5413 CRB and Roads
CRB and Roads Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) ...
- QT_地图导航 源码下载
https://github.com/douzujun/MyMapView 主要算法讲解: 1. 计算最短路径(dijkstra算法) Step1: (1)找到最短路径已经确定的顶点,从它已经确定的顶 ...
- Android studio 自动导入(全部)包 import
http://blog.csdn.net/buaaroid/article/details/44979629 1 Android studio 只有import单个包的快捷键:Alt+Enter.没有 ...
- MSVCR120.dll丢失问题
一.问题:丢失MSVCR120.dll 二.解决方法 到官网下载vcredist_x86.exe安装即可 地址:https://www.microsoft.com/en-us/download/det ...
- linux4.10.8 内核移植(四)---字符设备驱动_led驱动程序
一.字符设备驱动程序介绍 app里面用 open.read.write等等函数出来操作底层硬件.驱动程序中也有对应的xxx_open等函数.怎么找到驱动程序中的函数依赖于驱动程序框架. 二.搭建驱动程 ...
- wireshark数据包分析
最近有不少同事开始学习Wireshark,他们遇到的第一个困难就是理解不了主界面上的提示信息,于是跑来问我.问的人多了,我也总结成一篇文章,希望对大家有所帮助.Wireshark的提示可是其最有价值之 ...
- OpenCV中MAT中数据类型的设置(转)
前言 opencv中很多数据结构为了达到內存使用的最优化,通常都会用它最小上限的空间来分配变量,有的数据结构也会因为图像文件格式的关系而给予适当的变量,因此需要知道它们声明的空间大小来配置适当的变量. ...
- .net 加密与解密
public class Encrypts { /// <summary> /// 构造方法 /// </summary> public Encrypts() { } /// ...
- Django学习手册 - 模板继承与导入
核心: PS:一个页面只能继承一个模板. 前置: 配置url. 配置views 关键字: 1. {% extends "index模板.html" %} 声明继承于哪个模板 ,关联 ...
- CentOS中安装Nginx
一.背景 最近在写一些自己的项目,用到了nginx,所以自己动手来在Centos7上安装nginx,以下是安装步骤. 二.基本概念以及应用场景 1.什么是nginx Nginx是一款使用C语言开发的高 ...