A. Watchmen(Codeforces 650A)
A. Watchmen
3 seconds
256 megabytes
standard input
standard output
Watchmen are in a danger and Doctor Manhattan together with his friend Daniel Dreiberg should warn them as soon as possible. There are n watchmen on a plane, the i-th watchman is located at point (xi, yi).
They need to arrange a plan, but there are some difficulties on their way. As you know, Doctor Manhattan considers the distance between watchmen i and j to be |xi - xj| + |yi - yj|. Daniel, as an ordinary person, calculates the distance using the formula .
The success of the operation relies on the number of pairs (i, j) (1 ≤ i < j ≤ n), such that the distance between watchman i and watchmen j calculated by Doctor Manhattan is equal to the distance between them calculated by Daniel. You were asked to compute the number of such pairs.
The first line of the input contains the single integer n (1 ≤ n ≤ 200 000) — the number of watchmen.
Each of the following n lines contains two integers xi and yi (|xi|, |yi| ≤ 109).
Some positions may coincide.
Print the number of pairs of watchmen such that the distance between them calculated by Doctor Manhattan is equal to the distance calculated by Daniel.
3
1 1
7 5
1 5
2
6
0 0
0 1
0 2
-1 1
0 1
1 1
11
In the first sample, the distance between watchman 1 and watchman 2 is equal to |1 - 7| + |1 - 5| = 10 for Doctor Manhattan and for Daniel. For pairs (1, 1), (1, 5) and (7, 5), (1, 5) Doctor Manhattan and Daniel will calculate the same distances.
思路:Manhattan and Daniel will calculate the same distances曼哈顿距离和两点间的距离相等,A(x1,y1) ,B(X2,Y2);
|x1-x2|+|y1-y2|=sqrt((x1-x2)^2+(y1-y2)^2);
画个三角形你可以发现曼哈顿距离就是两直角边的和,而两点的距离为斜边
那么当且x1==x2||y1==y2;这两种距离相等
那么只要找x1==x2||y1==y2,开个数组记录各个x的种类及其个数,y的种类和个数,c[x],b[y],由于x和y的数值比较大所以离散化下可以。
sum+=c[x]*(c[x]-1)/2(c[x]〉=1);sum+=c[y]*(c[y]-1)/2;最如果点相同这样算就相当重复算了一遍,所以只要再找出那些相同的点,以及种类个数
R[i];ans+=(R[i]*(R[i]-1)/2;最后答案就是sum-ans;
1 #include<stdio.h>
2 #include<algorithm>
3 #include<iostream>
4 #include<stdlib.h>
5 #include<string.h>
6 #include<map>
7 #include<queue>
8 #include<math.h>
9 #include<set>
10 #include<stack>
11 #include<map>
12 int cmp(const void*p,const void*q);
13 using namespace std;
14 typedef long long LL;
15 typedef struct pp
16 {
17 LL x;
18 LL y;
19 } ss;
20 ss aa[200005*4];LL bb[200005*4];
21 ss ak[200005*4];ss bk[200005*4];
22 LL cc[4*200005];LL yy[200005*4];
23 LL vv[200005*4];
24 typedef pair<int,int> P;
25 int main(void)
26 {
27 LL i,j,k,p,q;
28 scanf("%I64d",&k);
29 { LL cnt=0;LL x,y;memset(vv,0,sizeof(vv));
30 map<P,LL>my;memset(yy,0,sizeof(yy));my.clear();
31 for(i=0;i<k;i++)
32 {
33 scanf("%I64d %I64d",&x,&y);
34 bb[cnt++]=x;
35 bb[cnt++]=y;
36 }
37 for(i=0;i<cnt;i++)
38 {
39 aa[i].x=bb[i];
40 aa[i].y=i;
41 }
42 qsort(aa,cnt,sizeof(ss),cmp);
43 cc[0]=0;LL ans=0;
44 for(i=1;i<cnt;i++)
45 {
46 if(aa[i].x!=aa[i-1].x)
47 ans++;
48 cc[aa[i].y]=ans;
49 }LL uu=0;
50 for(i=0;i<cnt;i++)
51 {
52 if(i%2==0)
53 {
54 ak[uu].x=cc[i];
55 }
56 else {ak[uu].y=cc[i];uu++;}
57 }LL rns=0;LL bbq=1;
58 for(i=0;i<uu;i++)
59 {P l;l.first=ak[i].x;l.second=ak[i].y;
60 if(my[l]==0)
61 {
62 my[l]=bbq++;
63 }
64 }for(i=0;i<uu;i++)
65 {P l;l.first=ak[i].x;l.second=ak[i].y;
66 vv[my[l]]++;
67 }
68 LL an=0;
69 for(i=1;i<bbq;i++)
70 {
71 if(vv[i]>=2)
72 {
73 an+=vv[i]*(vv[i]-1)/2;
74 }
75 }
76 for(i=0;i<uu;i++)
77 {
78 yy[ak[i].x]++;
79 }LL sum=0;
80 for(i=0;i<500005;i++)
81 {
82 if(yy[i]>=2)
83 {
84 sum+=yy[i]*(yy[i]-1)/2;
85 }
86 }memset(yy,0,sizeof(yy));
87 for(i=0;i<uu;i++)
88 {
89 yy[ak[i].y]++;
90 }
91 for(i=0;i<500005;i++)
92 {
93 if(yy[i]>=2)
94 {
95 sum+=yy[i]*(yy[i]-1)/2;
96 }
97 }
98 printf("%I64d\n",sum-an);
99 }
100 return 0;
101 }
102
103 int cmp(const void*p,const void*q)
104 {
105 ss*nn=(ss*)p;
106 ss*mm=(ss*)q;
107 return nn->x-mm->x;
108 }
A. Watchmen(Codeforces 650A)的更多相关文章
- Watchmen CodeForces - 650A
Watchmen CodeForces - 650A Watchmen are in a danger and Doctor Manhattan together with his friend Da ...
- Codeforces 650A Watchmen
传送门 time limit per test 3 seconds memory limit per test 256 megabytes input standard input output st ...
- (水题)Codeforces - 650A - Watchmen
http://codeforces.com/contest/650/problem/A 一开始想了很久都没有考虑到重复点的影响,解欧拉距离和曼哈顿距离相等可以得到 $x_i=x_j$ 或 $y_i=y ...
- codeforces Codeforces 650A Watchmen
题意:两点(x1,y1), (x2,y2)的曼哈顿距离=欧几里得距离 也就是:x1=x2或y1=y2,再删除重合点造成的重复计数即可. #include <stdio.h> #includ ...
- [刷题codeforces]650A.637A
650A Watchmen 637A Voting for Photos 点击查看原题 650A又是一个排序去重的问题,一定要注意数据范围用long long ,而且在写计算组合函数的时候注意也要用l ...
- Codeforces Round #345 (Div. 1) A - Watchmen 容斥
C. Watchmen 题目连接: http://www.codeforces.com/contest/651/problem/C Description Watchmen are in a dang ...
- Codeforces Round #345 (Div. 1) A. Watchmen
A. Watchmen time limit per test 3 seconds memory limit per test 256 megabytes input standard input o ...
- CodeForces 651C Watchmen map
Watchmen are in a danger and Doctor Manhattan together with his friend Daniel Dreiberg should warn t ...
- Codeforces Round #345 (Div. 1) A. Watchmen 模拟加点
Watchmen 题意:有n (1 ≤ n ≤ 200 000) 个点,问有多少个点的开平方距离与横纵坐标的绝对值之差的和相等: 即 = |xi - xj| + |yi - yj|.(|xi|, |y ...
随机推荐
- Kubernetes主机间cluster ip时通时不通
1.问题现象 测试部署了一个service,包括2个pod,分别在node1和node2上. $ kubectl get svc NAME CLUSTER-IP EXTERNAL-IP PORT(S) ...
- 用原生CSS编写-怦怦跳的心
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- 巩固javaweb第十四天
巩固内容: 单行文本框: 单行文本框的基本语法格式如下: < input type="text" name="输入信息的字" value=" ...
- abuse
abuse 近/反义词: ill-treat, maltreat, mistreat, misuse, prostitute, spoil; defame, disparage, malign, re ...
- LeetCode382-链表随机节点
原题链接:[382. 链表随机节点]:https://leetcode-cn.com/problems/linked-list-random-node/ 题目描述: 给定一个单链表,随机选择链表的一个 ...
- Advanced C++ | Virtual Constructor
Can we make a class constructor virtual in C++ to create polymorphic objects? No. C++ being static t ...
- NSMutableArray-->NSString
1.如何把NSMutableArray 转化为NSString//用字符将NSArray中的元素拼接起来 NSArray *array = [NSArray arrayWithObjects:@&qu ...
- Mysql的行级锁
我们首先需要知道的一个大前提是:mysql的锁是由具体的存储引擎实现的.所以像Mysql的默认引擎MyISAM和第三方插件引擎 InnoDB的锁实现机制是有区别的. Mysql有三种级别的锁定:表级锁 ...
- UIButton总结
UIButton 1. 功能 既能显示文字,又能显示图片(能显示2张图片,背景图片.内容图片) 长按高亮的时候可以切换图片\文字 直接通过addTarget...方法监听点击 2. 状态 normal ...
- Linux(CentOS 7)使用gcc编译c,c++代码
安装gcc: 1.使用 yum -list gcc* 查询 centos 官方gcc的所有包: 可安装的软件包 gcc.x86_64 gcc-c++.x86_64 gcc-gfortran.x86_6 ...