菜鸟第一次这么彻底的完全脱稿写线段树 因为数组开小了 re一次  真心建议 硬憋自己脱稿写一次,对线段树的理解一下子就上升了,呵呵!!!
#include<iostream>
#include<stdio.h>
#include<algorithm>
using namespace std;
struct node
{int l;int r;int s;
}a[400000];
int b[100005],c[100005],d[100005],e[100005],ans,n;
void buildtree(int i,int left,int right){///建树a[i].l=left;a[i].r=right;a[i].s=-1;if(a[i].l==a[i].r)return ;int mid=(left+right)/2;buildtree(i*2,left,mid);buildtree(i*2+1,mid+1,right);
}
void insert(int i,int left,int right,int sum){///对线段进行染色!!if((a[i].l!=a[i].r) &&(a[i].s!=-1)){///如果线段被覆盖 标记下传a[i*2].s=a[i].s;a[i*2+1].s=a[i].s;a[i].s=-1;}if(left==a[i].l&&right==a[i].r){///找到线段后染色a[i].s=sum;return ;}int mid=(a[i].l+a[i].r)>>1;if(mid>=right)insert(i*2,left,right,sum);elseif(mid<left)insert(i*2+1,left,right,sum);else{insert(i*2,left,mid,sum);insert(i*2+1,mid+1,right,sum);}return ;
}
int find(int x,int cou){///二分查找int l=1;int r=cou-1;while(r>=l){int mid=(l+r)>>1;if(x>c[mid])l=mid+1;if(x<c[mid])r=mid-1;if(x==c[mid])return mid;}return r;
}
void querry(int i){///询问有多少不同的颜色if(a[i].s!=-1){if(d[a[i].s]==0){ans++;d[a[i].s]=1;}return ;}if(a[i].l==a[i].r)return ;querry(i*2);querry(i*2+1);
}
int main()
{int ca,x,y;scanf("%d",&ca);while(ca--){scanf("%d",&n);for(int i=0;i<=n;i++)d[i]=0;int cou=0;for(int i=0;i<n;i++){scanf("%d",&b[cou++]);scanf("%d",&b[cou++]);}for(int i=0;i<cou;i++)e[i]=b[i];sort(b,b+cou);int couc=cou;b[cou]=-1;cou=1;for(int i=0;i<couc;i++){///离散话,庸俗的说法就是去重,压缩数据,使数据范围变小if(b[i]==b[i+1])continue;c[cou++]=b[i];}buildtree(1,1,cou-1);int tx,ty;int temp=1;int te=0;for(int i=0;i<n;i++){int xx=find(e[te++],cou);int yy=find(e[te++],cou);insert(1,xx,yy,temp++);}ans=0;querry(1);printf("%d\n",ans);}return 0;
}

poj 2528 Mayor's posters 线段树+离散话!!!相关推荐

  1. poj 2528 Mayor's posters (线段树+离散化)

    /*离散化+线段树由于 数据的输入最大是 10000000 ,直接用开数组肯点会超,所以要将起离散话,首先 ,我们存储输入的边,将其离散化,后面的就和一般的线段树一样可. */#include< ...

  2. POJ - 2528 Mayor's posters(线段数+离散化)

    题目链接:点击查看 题目大意:给定一个长度为1e7的墙,然后给出n张海报,每张海报都会占据墙上的一部分宽度,问按照给出的次序往墙上贴海报, 最后有几张海报能露出来(露出部分也算) 题目分析:线段树的区 ...

  3. poj 2528 Mayor's posters(线段树+离散化)

    1 /* 2 poj 2528 Mayor's posters 3 线段树 + 离散化 4 5 离散化的理解: 6 给你一系列的正整数, 例如 1, 4 , 100, 1000000000, 如果利用 ...

  4. POJ 2528 Mayor's posters(线段树)

    题目大意 贴海报.每张海报的高度都是一样的,唯独宽度不一样.每张海报只能占用整数倍的单位线段长度,贴了 n(n<=10000) 张海报之后,有几张能够看见(有一个角能看见这张海报也算被看见了)? ...

  5. poj 2528 Mayor's posters(线段树 离散化 区间更新 贴海报)

         这个题目本来对大神来说可能是水题, 对我就不行了,昨晚非折腾到下半夜一点 搞定, 并且可以总结出 ,只有把问题想清楚,或着看人家解题报告自己把问题和代码思路 搞清楚,才能谈的上调bug,否则 ...

  6. 离散化/线段树 (POJ - 2528 Mayor's posters)

    Mayor's posters https://vjudge.net/problem/POJ-2528#author=szdytom 线段树 + 离散化 讲解:https://blog.csdn.ne ...

  7. POJ 2528 Mayor's posters (离散化和线段树使用)

    还是做了线段树的题目,玩了两天也要继续看看题目了.之前就有看离散化的概念,大家可以去百度百科一下,简单转载一个例子 离散化 的大概思路 : 比如说给你一组 数据 1 4 1000 100000, 如果 ...

  8. POJ 2528 Mayor's posters 贴海报 线段树 区间更新

    注意离散化!!!线段树的叶子结点代表的是一段!!! 给出下面两个简单的例子应该能体现普通离散化的缺陷: 1-10 1-4 5-10 1-10 1-4 6-10 普通离散化算出来的结果都会是2,但是第二 ...

  9. POJ - 2528 Mayor's posters (浮水法+线段树/离散化+线段树)

    题目链接 题意: n(n<=10000)个人依次贴海报,给出每张海报所贴的范围li,ri(1<=li<=ri<=10000000) .求出最后还能看见多少张海报. 分析1 离散 ...

  10. POJ Mayor's posters——线段树+离散化

    原文:http://blog.163.com/cuiqiongjie@126/blog/static/85642734201261151553308/ 大致题意: 有一面墙,被等分为1QW份,一份的宽 ...

最新文章

  1. 人脸识别技术在支付场景的机遇与挑战
  2. IDEA使用过程中相应的配置和设置(如编码设置、窗口调整以及config.xml文件模板创建、工程打开方式、约束文件)
  3. debian6 xen4.0安装 guest半虚拟化--debootstrap安装
  4. 转 Intellij中的常用快捷键
  5. python数据分析与应用
  6. 《python 源码剖析》 读后总结(虚拟机综述)
  7. Window捕获消息机制及动态创建button-MFC
  8. 如何安装matlab?官网下载详细教程
  9. 垂直行业大数据分层架构图
  10. java代码生成可识别二维码
  11. 【职场加油站】给职场新人的几条忠告
  12. 中国移动光猫 GM220-S 改桥接简易教程(安徽移动)
  13. Linux下ps参数详解
  14. SAP BW/4 HANA基础学习(二)
  15. Dual Band Wireless-AC 3165无线驱动无法开启wifi
  16. 字符串和数组的长度 java c++
  17. pta 试试手气 C语言
  18. 课堂上学生的经典插嘴
  19. 先有鸿钧后有天,陆压道君还在前
  20. Centos8工具linux_info_pub.sh(支持linux主机一键打印各种常用信息如:CPU/ram/disk资源、linux资源)

热门文章

  1. OC省字典的数组摘要集
  2. 为什么selenium定位不到元素
  3. Mysql表编码查看修改
  4. 十六、oracle 索引
  5. Delphi 小知识汇总
  6. E - Elevator
  7. 物联网架构成长之路(22)-Docker练习之Etcd服务搭建
  8. shop--8.商品类别--批量操作--添加(前端)
  9. 分布式存储系统设计的关键问题
  10. Spring+Netty4实现的简单通信框架