极大团个数:POJ 2989

#include <cstdio>
#include <cstring>
using namespace std;
const int maxn = 130;
bool mp[maxn][maxn];
int some[maxn][maxn], none[maxn][maxn], all[maxn][maxn];
int n, m, ans;
void dfs(int d, int an, int sn, int nn)
{
    if(!sn && !nn) ++ans;
    int u = some[d][0];
    for(int i = 0; i < sn; ++i)
    {
        int v = some[d][i];
        if(mp[u][v]) continue;
        for(int j = 0; j < an; ++j)
        all[d+1][j] = all[d][j];
        all[d+1][an] = v;
        int tsn = 0, tnn = 0;
        for(int j = 0; j < sn; ++j)
        if(mp[v][some[d][j]])
        some[d+1][tsn++] = some[d][j];
        for(int j = 0; j < nn; ++j)
        if(mp[v][none[d][j]])
        none[d+1][tnn++] = none[d][j];
        dfs(d+1, an+1, tsn, tnn);
        some[d][i] = 0, none[d][nn++] = v;
    }
}
int work()
{
    ans = 0;
    for(int i = 0; i < n; ++i) some[1][i] = i+1;
    dfs(1, 0, n, 0);
    return ans;
}
int main()
{
    while(~scanf("%d %d", &n, &m))
    {
        memset(mp, 0, sizeof mp);
        for(int i = 1; i <= m; ++i)
        {
            int u, v;
            scanf("%d %d", &u, &v);
            mp[u][v] = mp[v][u] = 1;
        }
        int tmp = work();
        printf("%d\n", tmp);
    }
    return 0;
}
View Code

相关文章:

  • 2021-12-20
  • 2021-06-20
  • 2022-01-05
  • 2022-12-23
  • 2021-05-25
  • 2021-09-13
  • 2021-10-21
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2022-02-19
  • 2021-10-06
  • 2022-01-03
  • 2022-12-23
  • 2021-12-17
  • 2022-12-23
相关资源
相似解决方案