自己做的是从下往上扫描的,一直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次覆盖的更多相关文章

  1. HDU 4862 Jump(最小K路径覆盖)

    输入一个n×m网格图,每个结点的值为0-9,可以从任意点出发不超过k次,走完每个点且仅访问每个结点一次,问最终的能量最大值.不可全部走完的情况输出-1. 初始能量为0. 而结点(x,y)可以跳跃到结点 ...

  2. 网络费用流-最小k路径覆盖

    多校联赛第一场(hdu4862) Jump Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Ot ...

  3. UVA-11983-Weird Advertisement(线段树+扫描线)[求矩形覆盖K次以上的面积]

    题意: 求矩形覆盖K次以上的面积 分析: k很小,可以开K颗线段树,用sum[rt][i]来保存覆盖i次的区间和,K次以上全算K次 // File Name: 11983.cpp // Author: ...

  4. Comet OJ 茶颜悦色 线段树+扫描线(矩形覆盖最多点+优化)

    题目:https://www.cometoj.com/contest/59/problem/D?problem_id=2713 题意:给你一个正方形,然后给你n个点,这个正方形能随意放哪,要求那个正方 ...

  5. POJ 2482 扫描线(面积覆盖最大次数)

    Stars in Your Window Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 10806   Accepted:  ...

  6. hdu 4862 KM算法 最小K路径覆盖的模型

    http://acm.hdu.edu.cn/showproblem.php?pid=4862 选t<=k次,t条路要经过全部的点一次而且只一次. 建图是问题: 我自己最初就把n*m 个点分别放入 ...

  7. [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 ...

  8. POJ 3261 字符串上的k次覆盖问题

    题目大意: 给定一个数组,求一个最大的长度的子串至少出现过k次 一个子串出现多次,也就是说必然存在2个子串间的前缀长度为所求的值 通过二分答案,通过线性扫一遍,去判断出现次数,也就是说每次遇见一个he ...

  9. poj3680 Intervals 区间k覆盖问题 最小费用最大流 建图巧妙

    /** 题目:poj3680 Intervals 区间k覆盖问题 最小费用最大流 建图巧妙 链接:http://poj.org/problem?id=3680 题意:给定n个区间,每个区间(ai,bi ...

随机推荐

  1. LoadRunner进行参数化的九种方式取值和连接数据库取值

    一.连接mysql数据库取值 1.首先安装odbc驱动 链接: https://pan.baidu.com/s/1WAYd4ygQqIrbB08S01hSkg 提取码: gdfs 2.操作步骤如下图: ...

  2. FZU - 1688 Binary land

    题目链接  Problem 1688 Binary land Accept: 72    Submit: 171Time Limit: 1000 mSec    Memory Limit : 3276 ...

  3. POJ2516 Minimum Cost【最小费用最大流】

    题意: 有N个客户,M个仓库,和K种货物.已知每个客户需要每种货物的数量,每个仓库存储每种货物的数量,每个仓库运输各种货物去各个客户的单位费用.判断所有的仓库能否满足所有客户的需求,如果可以,求出最少 ...

  4. B. Planning The Expedition

    题目链接:http://codeforces.com/contest/1011/problem/B 题目大意: 输入的n,m代表n个人,m个包裹. 标准就是 每个人一开始只能选定吃哪一个包裹里的食物, ...

  5. JavaScript练习 - 模态对话框

    模态对话框练习 <!DOCTYPE html> <html lang="en"> <head> <meta charset="U ...

  6. activity 解析

    acitvity的四种状态: running.paused.stopped.killed 生命周期: onCreate()用来加载资源布局 onStart()启动activity,用户已经可以看到界面 ...

  7. Ubuntu/Debian 8 安装 Intel realsense 摄像头驱动

    ## Make Ubuntu/Debian Up-to-date1. sudo apt-get update && sudo apt-get upgrade && su ...

  8. vscode常用快捷键和插件(持续更新),以及一些常用设置的坑和技巧

    一 常用快捷键 ctrl+shift+p:  打开命令面板,最常用了 ctrl+p: 搜索窗口: 直接输入文件名,跳转到文件 > 可以进入 Ctrl+Shift+P 模式 ? 列出当前可执行的动 ...

  9. 【黑客免杀攻防】读书笔记5 - PE格式讲解

    0x01 MS-DOS头 MS-DOS头部的字段重点关注e_magic与最后一个e_lfanew是需要关注的. 第一个e_magic字段的值为4D5A,作用是可以作为判断这个文件是否是PE文件. 最后 ...

  10. sublime3添加python编译系统

    好记性不如烂笔头 为sublime3添加python编译系统,这里使用的anonconda2中的python.exe(即python2.7版本) 步骤: (1)打开sublime,打开“工具-> ...