#include #include using namespace std; typedef long long ll; const int INF = 1<<30; const ll INFLL = 1LL<<60; const ll MOD = 998244353; const double INFD = 1.0E18; const int dx[4] = {1, 0, -1, 0}; const int dy[4] = {0, -1, 0, 1}; //const int dx[8] = {1, 1, 0, -1, -1, -1, 0, 1}; //const int dy[8] = {0, 1, 1, 1, 0, -1, -1, -1}; using Pair = pair; using Graph = vector>>; using mint = atcoder::modint1000000007; int main(){ ios::sync_with_stdio(false); cin.tie(nullptr); cout << fixed << setprecision(15); int n, m, k; cin >> n >> m >> k; vector recieve(k);//景品がある場所 for (int i = 0; i < k; i++){ cin >> recieve[i]; recieve[i]--; } vector> dist(n, vector(n)); for (int i = 0; i < n; i++){ for (int j = 0; j < n; j++){ cin >> dist[i][j]; } } int ans = INF; for (int i = 0; i < n; i++){ vector> dp(1<(n, INF)); using Pair = tuple; priority_queue, greater> pq; pq.emplace(0, 1<> p) & 1) continue; if (dp[state | 1<