結果
問題 |
No.519 アイドルユニット
|
ユーザー |
![]() |
提出日時 | 2019-12-25 13:18:06 |
言語 | Java (openjdk 23) |
結果 |
TLE
|
実行時間 | - |
コード長 | 1,187 bytes |
コンパイル時間 | 2,275 ms |
コンパイル使用メモリ | 77,804 KB |
実行使用メモリ | 88,180 KB |
最終ジャッジ日時 | 2024-09-24 21:04:34 |
合計ジャッジ時間 | 6,901 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | TLE * 1 -- * 33 |
ソースコード
import java.util.*; public class Main { static int[][] matrix; static int n; static HashMap<Integer, Integer> map = new HashMap<>(); public static void main(String[] args) { Scanner sc = new Scanner(System.in); n = sc.nextInt(); matrix = new int[n][n]; for (int i = 0; i < n; i++) { for (int j = 0; j < n; j++) { matrix[i][j] = sc.nextInt(); } } System.out.println(getCount(0)); } static int getCount(int key) { if (key == (int)(Math.pow(2, n)) - 1) { return 0; } if (map.containsKey(key)) { return map.get(key); } int max = 0; for (int i = 0; i < n; i++) { if (((int)(Math.pow(2, i)) & key) != 0) { continue; } for (int j = i + 1; j < n; j++) { if (((int)(Math.pow(2, j)) & key) != 0) { continue; } max = Math.max(max, matrix[i][j] + getCount(key + (int)(Math.pow(2, i)) + (int)(Math.pow(2, j)))); } } map.put(key, max); return max; } }