import java.util.*; public class Main { static int[][] matrix; static HashMap dp = new HashMap<>(); static int n; 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(); } } dp.put(0, 0); System.out.println(dfw((1 << n) - 1)); } static int dfw(int mask) { if (dp.containsKey(mask)) { return dp.get(mask); } int max = 0; for (int i = 0; i < n - 1; i++) { if ((mask & (1 << i)) == 0) { continue; } for (int j = i + 1; j < n; j++) { if ((mask & (1 << j)) == 0) { continue; } max = Math.max(max, matrix[i][j] + dfw((mask ^ (1 << i)) ^ (1 << j))); } } dp.put(mask, max); return max; } }