結果
| 問題 | No.241 出席番号(1) | 
| コンテスト | |
| ユーザー |  moti | 
| 提出日時 | 2015-07-21 13:47:16 | 
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) | 
| 結果 | 
                                WA
                                 
                             | 
| 実行時間 | - | 
| コード長 | 1,127 bytes | 
| コンパイル時間 | 721 ms | 
| コンパイル使用メモリ | 82,952 KB | 
| 実行使用メモリ | 5,376 KB | 
| 最終ジャッジ日時 | 2024-07-08 11:32:28 | 
| 合計ジャッジ時間 | 3,541 ms | 
| ジャッジサーバーID (参考情報) | judge2 / judge1 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 3 | 
| other | AC * 18 WA * 11 | 
ソースコード
#include <iostream>
#include <algorithm>
#include <cmath>
#include <vector>
#include <complex>
#include <queue>
#include <set>
#include <map>
#include <cstring>
using namespace std;
#define REP(i,a,b) for(int i=a;i<(int)b;i++)
#define rep(i,n) REP(i,0,n)
typedef long long ll;
int constexpr MAX_V = 55;
vector<int> G[MAX_V];
int used[MAX_V];
int match[MAX_V];
int N;
bool find_augment_path(int v) {
  used[v] = 1;
  for(int u: G[v]) {
    int w = match[u];
    if(w < 0 || (!used[w] && find_augment_path(w))) {
      match[v] = u;
      match[u] = v;
      return true;
    }
  }
  return false;
}
int bipartite_matching() {
  memset(match, -1, sizeof match);
  int ret = 0;
  rep(i, N) {
    memset(used, 0, sizeof used);
    if(find_augment_path(i)) { ret ++; }
  }
  return ret;
}
int main() {
  cin >> N;
  rep(i, N) {
    int denial; cin >> denial;
    rep(j, N) {
      if(j != denial) {
        G[i].push_back(N+j);
        G[N+j].push_back(i);
      }
    }
  }
  if(bipartite_matching() != N) {
    cout << -1 << endl;
  }
  else {
    rep(i, N) {
      cout << match[i]-N << endl;
    }
  }
  return 0;
}
            
            
            
        