poj 1971 Parallelogram Counting(数学题)

【题目大意】:给出n个点,求出这n个点能够组成平行四边形的个数。

【解题思路】:

1)平行四边形的对角线的中点一定相交。<=> 如果有两条不同线段的中点相交,就是一个平行四边形

2)利用点坐标求出中点的集合,离散化后求出同个中点的出现的个数k。
3)对于每一个k ,利用组合公式C(k,2)的答案就是平行四边行的个数


【代码】:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <vector>
#include <queue>
#include <cmath>
#include <string>
#include <cctype>
#include <map>
#include <iomanip>
                   
using namespace std;
                   
#define eps 1e-8
#define pi acos(-1.0)
#define inf 1<<30
#define pb push_back
#define lc(x) (x << 1)
#define rc(x) (x << 1 | 1)
#define lowbit(x) (x & (-x))
#define ll long long

struct Node{
   int x,y;
}node[1010],mid[1001000];
int T,n,summ,num;

int cmp(const Node &a,const Node &b){
    if (a.x==b.x) return a.y<b.y; else return a.x<b.x;
}

int count(int k){
    if (k==1) return 0;
    else {
        return k*(k-1)/2;
    }
}

int main(){
    cin >> T;
    while (T--) {
        summ=0;
        scanf("%d",&n);
        for (int i=1; i<=n; i++) {
              scanf("%d%d",&(node[i].x),&(node[i].y));
          }
        num=-1;
        for (int i=1; i<=n; i++) {
            for (int j=i+1; j<=n; j++) {
                  num++;
                  mid[num].x=node[i].x+node[j].x;
                  mid[num].y=node[i].y+node[j].y;
              }
        }
        sort(mid,mid+num+1,cmp);
        Node temp;
        int k;
        k=1;
        for (int i=0; i<=num; i++) {
            if (mid[i].x==mid[i+1].x && mid[i].y==mid[i+1].y) k++;
            else {
                    summ+=count(k);
                    k=1;
                }
        }
        cout << summ << endl;

    }
    return 0;
}



你可能感兴趣的:(poj 1971 Parallelogram Counting(数学题))