zoukankan      html  css  js  c++  java
  • Codeforces Round #345 (Div. 1) A. Watchmen 模拟加点

    Watchmen

    题意:有n (1 ≤ n ≤ 200 000) 个点,问有多少个点的开平方距离与横纵坐标的绝对值之差的和相等;

    = |xi - xj| + |yi - yj|.(|xi|, |yi| ≤ 109)

    思路:开始想的是容斥原理,即按x,y分别排序,先计算同x的点,然后在计算同y的点,这时由于相同的点之间的连边已经算过了,这样就不能再算。并且同一个y的点中可以每个点有多个点,算是不好编码的(反正我敲了很久..WA了)

    反思:上面的容斥原理是从总体的思路来考虑的,这道题的难点也就是不重不漏。那么我们就模拟题目输入来往平面加点即可;每次加入一个点时,看与其同x,y有多少个点,这时由于当前点加了两次所以减去即可;坐标值较大,用map表示即可;

    时间复杂度O(n)

    #include<bits/stdc++.h>
    using namespace std;
    typedef __int64 ll;
    map<int,int> x,y;
    map<pair<int,int>,int> mp;
    
    int main()
    {
        int n,x,y;
        ll ans=0;
        scanf("%d",&n);
        while(n--)
        {
            scanf("%d%d",&x,&y);
        
    ans += x[a] + y[b] - mp[MK(a,b)]; x[a]++; y[b]++; mp[MK(a,b)]++;
      }
       printf(
    "%I64d ",ans);
    }
  • 相关阅读:
    清除微信浏览器缓存
    JS实现HTML标签转义及反转义
    mvc中服务器端、客户端属性验证
    Ajax.ActionLink参数详解
    Ajax.BeginForm参数详解
    AjaxHelper简介
    将博客搬至CSDN
    Sequelize小记
    端口: 查看端口状态
    搭建git服务器
  • 原文地址:https://www.cnblogs.com/hxer/p/5265877.html
Copyright © 2011-2022 走看看