【POJ No. 2352】数星星 Stars

北大OJ 题目地址

【题意】

星星由平面上的点表示,星星的等级为纵横坐标均不超过自己的星星数量(不包括自己)。下图中,

5号星的等级为3(纵横坐标均不超过5号星的星星有3颗:1、2和4号)。2和4号星的级别是1。

在该地图上有一颗0级星、两颗1级星、一颗2级星和一颗3级星。计算给定地图上每个级别的星星数量。

【输入输出】

输入:

第1行包含星星的数量N (1≤N ≤15000)。以下N 行描述星星的坐标,每行都包含两个整数X 、Y (0≤X ,Y ≤32000)。平面上的一个点只可以有一颗星星。以Y 坐标升序输入,在Y 坐标相等时以X 坐标升序输入。

输出:

输出包含N 行,第1行包含0级的星星数量,第2行包含1级的星星数量……最后一行包含N- 1级的星星数量。

【样例】

提示: 数据量巨大,这里使用scanf而不是cin来读取数据,避免超出时间限制。

【思路分析】

每颗星星的等级都为它左下方的星星个数。输入所有星星(按照y 升序,若y 相等,则x 升序)的坐标,依次输出等级0~n -1的星星数量。

输入样例的地图如下图所示,图中星星旁边的数字为输入顺序,1号星的左下没有星星,等级为0;2号星的左边有1颗星星,等级为1;3号星的左边有2颗星星,等级为2;4号星的左下有1颗星星,等级为1;5号星的左边有3颗星星,等级为3。因此等级为0的有1个,等级为1的有2个,等级为2的有1个,等级为3的有1个,等级为4的有0个。

本题看似二维数据,实际上输入数据已经按照y 升序,也就是说,读到一个点时,当前点的y 坐标肯定大于或等于已经输入的y 坐标。

如果y 坐标相等,则x 坐标肯定大于已经输入的x 坐标,所以每次只要计算x 坐标比当前点小的点就行了。该问题的本质是统计x 坐标前面星星的数量,是前缀和问题。因为数据量较大,暴力穷举会超时,所以可以借助树状数组解决。

注意:给的点坐标从0开始,树状数组下标从1开始(0的位置不可用),所以需要在输入x 坐标时加1处理。

【算法设计】

① 依次输入每一个坐标x 、y ,执行x ++。

② 计算x 的前缀和sum(x ),将其作为该星星的等级,用ans[]数组累计该等级的数量。

③ 将树状数组中x 的数量加1。

【算法实现】

#include<cstdio>using namespace std;#define maxn 32010
#define lowbit(x) (x)&(-x)int ans[maxn],c[maxn];//等级统计,每个值的数量
int n;void add(int i,int val){//将第i个元素增加val,其后继也要增加while(i<=maxn){//是x点的范围,注意不是星星的个数n c[i]+=val;i+=lowbit(i);//i的后继(父结点) }
}int sum(int i){//前缀和 int s=0;while(i>0){s+=c[i];i-=lowbit(i);//i的前驱}return s;
}int main(){scanf("%d",&n);int x,y;for(int i=0;i<n;i++){scanf("%d%d",&x,&y);x++;ans[sum(x)]++;add(x,1);//x的数量c[x]增1}for(int i=0;i<n;i++)printf("%d\n",ans[i]);return 0;
}

【POJ No. 2352】数星星 Stars相关推荐

  1. 1536:【例 2】数星星 Stars

    1536:[例 2]数星星 Stars [题目描述] 天空中有一些星星,这些星星都在不同的位置,每个星星有个坐标.如果一个星星的左下方(包含正左和正下)有 k 颗星星,就说这颗星星是 k 级的. 例如 ...

  2. [树状数组]数星星 Stars

    数 星 星 S t a r s 数星星 Stars 数星星Stars 题目描述 天空中有一些星星,这些星星都在不同的位置,每个星星有个坐标.如果一个星星的左下方(包含正左和正下)有 k k k 颗星星 ...

  3. 数星星 Stars 题解

    题目链接 分析 一道树状数组,但坑点比较多... 首先在草稿纸上画图可以得知:星星的等级与 x x x无关,至于 y y y的大小有关,于是我们可以根据输入顺序一一将其插入树状数组进行维护,此星星的等 ...

  4. 用ClickHouse在GitHub上数星星

    在最大的基友交友网站GitHub上,来自世界各地的开源开发者们进行着数百万个项目.这里每天都有大量的代码文档.修复和提交BUG之类的事件信息产生. 而GitHub Archive项目,正是搜集了这些G ...

  5. 2021年12月电子学会图形化三级编程题解析含答案:数星星

    [此题目来自2021年12月份电子学会] [青少年软件编程(图形化)等级考试试卷(三级)] 三.编程题(共3题,共30分) 36:数星星 Goblin有个很厉害的魔法:他一挥手就可以点亮夜空中五彩斑斓 ...

  6. 混合个人训练第四十六场(A,B题解) A 数论线代全家桶 (all) B: 看星星 (stars)

    A 数论线代全家桶 (all) 题意如图. 思路: 首先发现 1 = 1 * 1 * 1; n=1; 4 = 1 * 4 * 1; n=2; 72 = 4 * 18=4 * 9 * 2; n=3; 2 ...

  7. 2022年9月青少年软件编程(图形化)等级考试试卷--三级--数星星

    数星星 Goblin有个很厉害的魔法:他一挥手就可以点亮夜空中五彩斑斓的星星灯. 1.准备工作 (1)删除小猫角色,添加"Goblin"角色,并删除Goblin角色的造型" ...

  8. URAL 1028 数星星 题解

    URAL 1028 数星星 题解 URAL 1028 题目 Astronomers often examine star maps where stars are represented by poi ...

  9. 【电子学会】2021年12月图形化三级 -- 数星星

    数星星 Goblin有个很厉害的魔法:他一挥手就可以点亮夜空中五彩斑斓的星星灯. 1. 准备工作 (1)删除小猫角色,添加"Goblin"角色,并删除Goblin角色的造型&quo ...

最新文章

  1. 好礼相送|CSDN云原生 Meetup 成都站报名热烈启动,12.18见!
  2. Bokeh中图形与组件的布局简介 | Bokeh 小册子
  3. java war目录_java war包 路径--解决war包中文件路径问题
  4. servlet api.jar是干什么的?
  5. 如何提取sql语句中绑定变量的值?
  6. 在oracle数据库表中没有添加rowid字段为什么会出现?
  7. 在工作流引擎基础上搭建电子商务揽收系统解决方案
  8. 麦克纳姆轮全向移动机器人自旋转运动分析
  9. Linux-CentOS上一些快捷键的使用
  10. RGB图像任意角度旋转
  11. Flex 4 的ComboBox下拉框滚动条Scroller(VerticalScrollBar)的thumb过小问题的解决
  12. 邵阳学院学校云认证码_2021年湖南对口单招升学学校排名
  13. m7405d粉盒清零方法_打印机清零方法总览
  14. matlab 求平面方程,MATLAB求空间平面方程
  15. word中常用技巧,快速删除word中光标前或后的内容
  16. WPS做好一个PPT后,用microsoft系列的放映软件打开,出现空白页
  17. Android攻城狮四大组件之Service
  18. CMakeLists.txt链接库的基本套路
  19. sftp命令复制文件
  20. windows 防止屏保锁屏脚本工具

热门文章

  1. figure()用法
  2. CAD误操作怎么办?CAD撤销快捷键、CAD自动保存…
  3. 青海大学昆仑学院计算机机考,2020年6月青海大学昆仑学院英语四级考试科目有哪些?...
  4. 如何在应用交付上发布应用_面对应用交付中的新建与购买问题
  5. Flutter 根据图标工场网站 更改Android ios 桌面Logo
  6. 比较研究测井预测:遗传算法与神经网络(Matlab代码实现)
  7. 手机成语大词典java 手机词典
  8. [Android]commit already called错误解决
  9. 浅析OA办公系统未来的发展路径
  10. community 计算模块度_【转载】金融风控反欺诈之图算法