結果
| 問題 |
No.488 四角関係
|
| コンテスト | |
| ユーザー |
jp_ste
|
| 提出日時 | 2017-05-14 10:00:03 |
| 言語 | Java (openjdk 23) |
| 結果 |
AC
|
| 実行時間 | 340 ms / 5,000 ms |
| コード長 | 1,333 bytes |
| コンパイル時間 | 2,137 ms |
| コンパイル使用メモリ | 76,872 KB |
| 実行使用メモリ | 45,024 KB |
| 最終ジャッジ日時 | 2024-09-16 05:46:22 |
| 合計ジャッジ時間 | 7,376 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 22 |
ソースコード
import java.util.*;
public class Main {
static int n;
static int m;
static boolean list[][];
static int ans = 0;
public static void main(String[] args) throws Exception {
Scanner scan = new Scanner(System.in);
n = scan.nextInt();
m = scan.nextInt();
list = new boolean[n][n];
for(int i=0; i<m; i++) {
int left = scan.nextInt();
int right = scan.nextInt();
list[left][right] = true;
list[right][left] = true;
}
for(int i=0; i<n; i++) {
int connect[] = {i, -1, -1, -1};
solve(connect, 0);
}
System.out.println(ans/8);
}
static void solve(int con[], int index) {
int left = con[index];
if(index == 3) {
int right = con[0];
if(list[left][right]) {
if((!list[con[0]][con[2]]) && (!list[con[1]][con[3]])) {
ans++;
}
}
return;
}
for(int right=0; right<n; right++) {
if(index > 0) {
if(right == con[index-1]) continue;
}
if(list[left][right]) {
con[index+1] = right;
solve(con, index+1);
}
}
}
}
jp_ste