码迷,mamicode.com
首页 > 其他好文 > 详细

bzoj4264

时间:2017-08-23 00:39:05      阅读:116      评论:0      收藏:0      [点我收藏+]

标签:clu   ack   技术   one   哈希   bsp   printf   std   scanf   

哈希

cf原题。。。没见过的话真想不出来

将邻接表排序哈希,判断是否相同,但是会漏掉两点相邻的情况,于是再把自己加入自己的邻接表,然后再哈希判断。

技术分享
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 1000010;
vector<int> G[N];
int n, m; 
ll ans;
map<ll, ll> mp; 
int main()
{
    scanf("%d%d", &n, &m);
    for(int i = 1; i <= m; ++i)
    {
        int u, v;
        scanf("%d%d", &u, &v);
        G[u].push_back(v);
        G[v].push_back(u);
    }
    for(int i = 1; i <= n; ++i) 
    {       
        sort(G[i].begin(), G[i].end());
        G[i].erase(unique(G[i].begin(), G[i].end()), G[i].end());
        ll Hash = 0;
        for(int j = 0; j < G[i].size(); ++j)
            Hash = Hash * 1234567ll + G[i][j];
        ++mp[Hash];
    }   
    for(int i = 1; i <= n; ++i)
    {
        G[i].push_back(i);
        sort(G[i].begin(), G[i].end());
        G[i].erase(unique(G[i].begin(), G[i].end()), G[i].end());
        ll Hash = 0;
        for(int j = 0; j < G[i].size(); ++j)
            Hash = Hash * 1234567ll + G[i][j];
        ++mp[Hash];
    }
    for(map<ll, ll> :: iterator it = mp.begin(); it != mp.end(); ++it)
        ans += (it -> second) * (it -> second - 1ll) / 2ll;
    printf("%lld\n", ans);   
    return 0;
}
View Code

 

bzoj4264

标签:clu   ack   技术   one   哈希   bsp   printf   std   scanf   

原文地址:http://www.cnblogs.com/19992147orz/p/7414108.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!