結果
問題 | No.488 四角関係 |
ユーザー |
![]() |
提出日時 | 2017-02-26 15:04:06 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 5 ms / 5,000 ms |
コード長 | 1,060 bytes |
コンパイル時間 | 352 ms |
コンパイル使用メモリ | 56,164 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-06-11 16:38:54 |
合計ジャッジ時間 | 1,069 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 22 |
ソースコード
#include <iostream> using namespace std; int n, m; bool links[51][51] = { false }; int nodes[4]; int count(int node, int remaining) { nodes[remaining] = node; if (remaining == 0) { bool closed = true; for (int i = 0; i < 4; ++i) { int linkCount = 0; for (int k = 0; k < 4; ++k) { if (links[nodes[i]][nodes[k]]) { ++linkCount; } } if (linkCount != 2) { closed = false; break; } } return closed ? 1 : 0; } int result = 0; for (int i = node + 1; i < n; ++i) { result += count(i, remaining - 1); } return result; } int main(int argc, const char * argv[]) { cin >> n >> m; for (int i = 0; i < m; ++i) { int a, b; cin >> a >> b; links[a][b] = true; links[b][a] = true; } int result = 0; for (int i = 0; i < n; ++i) { result += count(i, 3); } cout << result << endl; return 0; }