【图和树基础】完全图判定

题目

输入一个无向图,判断这个图是不是一个完全图。

输入

输入第一行两个整数 n(1 <= n <= 100) 和 m(1 <= m <= 20000),表示输入点数和边数。

接下来 m 行,每行输入两个整数 u, v(1 <= u, v <= n),表示 u 和 v 之前有一条无向边。

输入中不存在自己到自己的边,但是可能会有重复的边。

输出

如果输入的图是一个完全图,输出"Yes",否则输出"No"。

题解

这道题非常简单就是道水题,直接上代码

AC代码

#include<iostream>
using namespace std;
int main() {
    int n, m;
    int flag = 1;
    cin >> n >> m;
    int u, v, g[n + 2][n + 2];
    for(int i = 0; i < m; i++) {
        cin >> u >> v;
        g[u][v] = 1;
        g[v][u] = 1;
    }
    for(int i = 1; i <= n; i++) {
        for(int j = i + 1; j <= n; j++) {
            if(g[i][j] != 1)
                flag = 0;
        }
    }
    if(flag == 0)
        cout << "No";
    else cout << "Yes";
    return 0;
}

猜你喜欢

转载自blog.csdn.net/qq_43398760/article/details/83186533