結果
問題 | No.488 四角関係 |
ユーザー |
![]() |
提出日時 | 2017-02-24 22:55:56 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 13 ms / 5,000 ms |
コード長 | 746 bytes |
コンパイル時間 | 645 ms |
コンパイル使用メモリ | 59,248 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2025-01-02 23:33:45 |
合計ジャッジ時間 | 1,498 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 22 |
ソースコード
#include <iostream> using namespace std; int N,M; int map[1230][1230]; bool has(int a, int b) { return map[a][b]; } bool valid(int* q) { int w[4] = {0}; for (int i=0; i<4; i++) { for (int j=0; j<4; j++) { if (i==j) continue; if (has(q[i], q[j])) { w[j]++; } } } for (int i=0; i<4; i++) { if (w[i] != 2) return false; } return true; } int main(){ cin >> N >> M; for (int i=0; i<M; i++) { int a,b; cin >> a >> b; map[a][b] = map[b][a] = true; } int ans = 0; for (int i=0; i<N; i++) { for (int j=i+1; j<N; j++) { for (int k = j+1; k<N; k++) { for (int l = k+1; l<N; l++) { int arr[4] = {i,j,k,l}; if (valid(arr)) { ans++; } } } } } cout << ans << endl; return 0; }