【题目描述】

码农有一块超新星屏幕,它有N个像素点,每个像素点有亮度和灰度两个参数,记为I和H, 范围都是0~32000.

一天,码农突发奇想,想知道哪个点比较容易亮瞎眼睛。为此,他定义了一个瞎眼指数: 瞎眼指数就是灰度和亮度均不大于该像素点的像素个数。

现在,码农希望知道,瞎眼指数为0~N-1的像素点分别有多少个

【输入格式】

第一行一个数字N,代表有N个像素点。接下来N行,每行两个数字,代表该像素点的亮度和灰度。

N个像素的亮度和灰度。像素按照灰度从小到大的顺序给出,(0 <= I, H <= 32000, N < 20000)

【输出格式】

输出:瞎眼指数从0到H-1之间各等级的像素个数。

【样例输入】

5

1 1

5 1

7 1

3 3

5 5

【样例输出】

1

2

1

1

0

排序树状数组。

先按亮度从小到大排好序,这样扫到一个点的时候,之前处理过的点亮度都不大于它。

然后用树状数组标记灰度,然后统计……

 /*by SilverN*/
#include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdio>
#include<cmath>
using namespace std;
const int mxn=;
struct point{
int l,h;
}d[mxn];
int a[mxn];
int ans[mxn];
int n;
int cmp(point a,point b){
if(a.l==b.l)return a.h<b.h;
return a.l<b.l;
}
inline int lowbit(int x){
return x&-x;
}
void add(int p,int x){
while(p<=n){
a[p]+=x;
p+=lowbit(p);
}
}
int ask(int x){
int res=;
while(x){
res+=a[x];
x-=lowbit(x);
}
return res;
}
int main(){
scanf("%d",&n);
int i,j;
for(i=;i<=n;i++)scanf("%d%d",&d[i].l,&d[i].h);
sort(d+,d+n+,cmp);
for(i=;i<=n;i++){
int tmp=ask(d[i].h);
add(d[i].h,);
ans[tmp]++;
}
for(i=;i<n;i++)printf("%d\n",ans[i]);
}

最新文章

  1. 2016福州大学软件工程第五、六次团队作业-Alpha阶段成绩汇总
  2. Android性能优化之内存优化练习
  3. iframe无刷新跨域并获得返回值
  4. Python数据类型之“数字(numerics)”
  5. JavaWeb(一)
  6. C++ fstream stringstream
  7. PHP超时处理全面总结(转)
  8. 【STL+模拟】UVa 506 - System Dependencies
  9. 【BZOJ 1412】[ZJOI2009]狼和羊的故事
  10. (转)linux bash shell 入门教程
  11. Unity 扩展属性自定义绘制
  12. 获取activity的根视图
  13. Redis安装完整步骤
  14. spring-petclinic性能调优实战(转)
  15. hanlp使用自定义词典抽取关键词
  16. 从零开始学 Web 之 Ajax(一)服务器相关概念
  17. 第一讲(3)osgearth编译
  18. jqGrid删除单条和多条数据
  19. jQuery Colorbox弹窗插件使用教程小结、属性设置详解以及colorbox关闭
  20. 浅谈IC行业产业链以及贸易商在产业链中的作用  2008-10-16 12:45[转自Michael的博客]

热门文章

  1. MySQL的隐式类型转换整理总结
  2. Huffman Tree -- Huffman编码
  3. POJ 3608 凸包间最短距离(旋转卡壳)
  4. python基础之生成器表达式形式、面向过程编程、内置函数部分
  5. [学习笔记]CSS选择器
  6. Android 用Chrome浏览器打开url 自定义样式
  7. STM8S PWM输出停止后 IO口电平输出
  8. C#学习你需要知道的---(For和Foreach)
  9. Android学习记录(9)—Android之Matrix的用法
  10. jpg、png、gif图片格式的浅析