結果
問題 | No.241 出席番号(1) |
ユーザー |
![]() |
提出日時 | 2015-07-21 13:48:01 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 1,128 bytes |
コンパイル時間 | 696 ms |
コンパイル使用メモリ | 83,468 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-11-30 21:31:31 |
合計ジャッジ時間 | 2,072 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 29 |
ソースコード
#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 = 105;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;}