传送门

分析

我就是个BT......

直接排序后开数组记录每条线上的信息,注意由于每个点只会影响前面第一个点和后面第一个点,所以记录每条线的前一个点就行了。

代码

#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<algorithm>
#include<cctype>
#include<cmath>
#include<cstdlib>
#include<ctime>
#include<queue>
#include<vector>
#include<set>
#include<map>
#include<stack>
using namespace std;
struct node {
int x,y;
};
node d[];
int px[],py[],pa[],pb[],tot[],ans[];
inline bool cmp(const node a,const node b){
return a.x==b.x?a.y<b.y:a.x<b.x;
}
int main(){
int n,m,i,j,k;
scanf("%d%d",&n,&m);
for(i=;i<=m;i++)scanf("%d%d",&d[i].x,&d[i].y);
sort(d+,d+m+,cmp);
for(i=;i<=m;i++){
int x=d[i].x,y=d[i].y;
if(px[x])tot[i]++,tot[px[x]]++;
if(py[y])tot[i]++,tot[py[y]]++;
if(pa[x+y])tot[i]++,tot[pa[x+y]]++;
if(pb[x-y+n])tot[i]++,tot[pb[x-y+n]]++;
px[x]=i,py[y]=i,pa[x+y]=i,pb[x-y+n]=i;
}
for(i=;i<=m;i++)ans[tot[i]]++;
for(i=;i<;i++)printf("%d ",ans[i]);
return ;
}

最新文章

  1. [LeetCode] Dungeon Game 地牢游戏
  2. Jenkins的Windows Slave分布式构建和部署
  3. 模仿迅L看看&lt;音频播放器&gt; 实现点击进度条,跳转播放
  4. MySQL Binlog Mixed模式记录成Row格式
  5. 详解MVC设计模式
  6. Chome v42 支持Java
  7. ajax+json+Struts2实现list传递实例讲解
  8. JS调用水晶报表打印翻页按钮事件
  9. centos 7
  10. rsync+sersync实现文件实时同步
  11. javascript笔记——placehold
  12. HDU4545+LCS
  13. 查询两个日期(时间)以内的数据,between and 或 and 连&gt;= &lt;=,to_date()
  14. newlisp获得bash该命令的退出状态
  15. TCP连接之未连接队列的理解[转]
  16. 记录python接口自动化测试--主函数(第六目)
  17. Zookeeper的安装配置及基本开发
  18. 关于bootstrap-fileinput
  19. BZOJ.3638.CF172 k-Maximum Subsequence Sum(模拟费用流 线段树)
  20. 《EMCAScript6入门》读书笔记——23.Module的加载实现

热门文章

  1. 《Effective C++》——条款08:别让异常逃离析构函数
  2. grunt-2x2x
  3. UVALive 3971 Assemble(二分+贪心)
  4. WC2019 I 君的商店
  5. 异步通信rabbitmq——消息重试
  6. 用php实现斐波那契数列
  7. jsp有哪些内置对象?作用分别是什么?
  8. (转)C#用Linq实现DataTable的Group by数据统计
  9. java代码写个进程条
  10. 关于pipe管道的读写端关闭问题