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