結果

提出番号 1607
提出者 tanzaku
言語 Java
提出日時 2018-08-04 13:15:50
問題名 (70)アルゴリズムのお勉強
結果 AC
点数 100%

テストケース

テストケース 結果 得点 実行時間 メモリ使用量
1 AC 100% 52ms 93728KB
2 AC 100% 66ms 93424KB
3 AC 100% 61ms 93792KB
4 AC 100% 53ms 93344KB
5 AC 100% 54ms 93648KB
6 AC 100% 55ms 93952KB
7 AC 100% 64ms 93152KB
8 AC 100% 55ms 93552KB
9 AC 100% 67ms 93648KB
10 AC 100% 60ms 92720KB
11 AC 100% 67ms 95296KB
12 AC 100% 64ms 92768KB
13 AC 100% 65ms 96432KB
14 AC 100% 62ms 93840KB
15 AC 100% 54ms 93904KB
16 AC 100% 60ms 94032KB
17 AC 100% 62ms 93536KB
18 AC 100% 54ms 92928KB
19 AC 100% 75ms 96160KB
20 AC 100% 72ms 95440KB
21 AC 100% 60ms 94032KB
22 AC 100% 86ms 95904KB
23 AC 100% 52ms 94304KB
24 AC 100% 92ms 97568KB
25 AC 100% 68ms 94784KB
26 AC 100% 80ms 97152KB
27 AC 100% 88ms 98800KB
28 AC 100% 70ms 95264KB
29 AC 100% 86ms 99024KB
30 AC 100% 83ms 95680KB

ソースコード

import java.io.OutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.PrintWriter;
import java.util.Arrays;
import java.io.IOException;
import java.io.BufferedReader;
import java.io.Reader;
import java.io.InputStreamReader;
import java.io.InputStream;

/**
 * Built using CHelper plug-in
 * Actual solution is at the top
 */
public class Main {
    public static void main(String[] args) {
        InputStream inputStream = System.in;
        OutputStream outputStream = System.out;
        MyInput in = new MyInput(inputStream);
        PrintWriter out = new PrintWriter(outputStream);
        TaskD solver = new TaskD();
        solver.solve(1, in, out);
        out.close();
    }

    static class TaskD {
        public void solve(int testNumber, MyInput in, PrintWriter out) {
            int n = in.nextInt();
            int[] t = in.nextIntArray(n);
            int[][] a = in.nextIntArray2D(n, n);

            int[] dp = new int[1 << n];
            Arrays.fill(dp, 1 << 29);
            dp[0] = 0;
            for (int i = 0; i < 1 << n; i++) {
                for (int j = 0; j < n; j++) {
                    int v = 0;
                    for (int k = 0; k < n; k++) {
                        v += (i >>> k & 1) * a[k][j];
                    }
                    dp[i | 1 << j] = Math.min(dp[i | 1 << j], dp[i] + t[j] - v);
                }
            }
            out.println(dp[(1 << n) - 1]);
        }

    }

    static class MyInput {
        private final BufferedReader in;
        private static int pos;
        private static int readLen;
        private static final char[] buffer = new char[1024 * 8];
        private static char[] str = new char[500 * 8 * 2];
        private static boolean[] isDigit = new boolean[256];
        private static boolean[] isSpace = new boolean[256];
        private static boolean[] isLineSep = new boolean[256];

        static {
            for (int i = 0; i < 10; i++) {
                isDigit['0' + i] = true;
            }
            isDigit['-'] = true;
            isSpace[' '] = isSpace['\r'] = isSpace['\n'] = isSpace['\t'] = true;
            isLineSep['\r'] = isLineSep['\n'] = true;
        }

        public MyInput(InputStream is) {
            in = new BufferedReader(new InputStreamReader(is));
        }

        public int read() {
            if (pos >= readLen) {
                pos = 0;
                try {
                    readLen = in.read(buffer);
                } catch (IOException e) {
                    throw new RuntimeException();
                }
                if (readLen <= 0) {
                    throw new MyInput.EndOfFileRuntimeException();
                }
            }
            return buffer[pos++];
        }

        public int nextInt() {
            int len = 0;
            str[len++] = nextChar();
            len = reads(len, isSpace);
            int i = 0;
            int ret = 0;
            if (str[0] == '-') {
                i = 1;
            }
            for (; i < len; i++) ret = ret * 10 + str[i] - '0';
            if (str[0] == '-') {
                ret = -ret;
            }
            return ret;
        }

        public char nextChar() {
            while (true) {
                final int c = read();
                if (!isSpace[c]) {
                    return (char) c;
                }
            }
        }

        int reads(int len, boolean[] accept) {
            try {
                while (true) {
                    final int c = read();
                    if (accept[c]) {
                        break;
                    }
                    if (str.length == len) {
                        char[] rep = new char[str.length * 3 / 2];
                        System.arraycopy(str, 0, rep, 0, str.length);
                        str = rep;
                    }
                    str[len++] = (char) c;
                }
            } catch (MyInput.EndOfFileRuntimeException e) {
            }
            return len;
        }

        public int[] nextIntArray(final int n) {
            final int[] res = new int[n];
            for (int i = 0; i < n; i++) {
                res[i] = nextInt();
            }
            return res;
        }

        public int[][] nextIntArray2D(final int n, final int k) {
            final int[][] res = new int[n][];
            for (int i = 0; i < n; i++) {
                res[i] = nextIntArray(k);
            }
            return res;
        }

        static class EndOfFileRuntimeException extends RuntimeException {
        }

    }
}