题目
输入一个无向图,判断这个图是不是一个完全图。
输入
输入第一行两个整数 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;
}