水面下の夢

競プロやイラストに興味があります.メインブログがここ.同人サークル「かのらぶ」のページはこっち( https://yumechi0525.amebaownd.com ).ブログアイコンはYaQ(@8_9_00)さんから.

ARC 042 A - 掲示板

さぼってた問題を解消してる.

回答

Submission #468717 - AtCoder Regular Contest 042 | AtCoder

当日は問題文流し見しかできず,うまく回答できなかった問題.
部分点は想定したとおり,入力されたとおりにシミュレーションを行う.ただし,配列が大きくなるようなケースになると当然これは通用しない.
満点回答は解説のとおり実装.書き込みのあったスレッドを逆順におい(最新の書き込み順というべきか),それを先に並べた上で,かきこみのなかったスレッドを数字の順に並べる.
A問題にしては少し難しいなという印象を受けた.

#include <iostream>
#include <cstdio>
#include <vector>
#include <queue>
 
#include <map>
#include <set>
#include <string>
#include <algorithm>
#include <functional>
using namespace std;
#define FOR(i,a,b) for (int i=(a);i<(b);i++)
#define RFOR(i,a,b) for (int i=(b)-1;i>=(a);i--)
#define REP(i,n) for (int i=0;i<(n);i++)
#define RREP(i,n) for (int i=(n)-1;i>=0;i--)
#define INF 1<<30
#define MP make_pair
#define mp make_pair
#define pb push_back
#define PB push_back
#define DEBUG(x) cout<<#x<<": "<<x<<endl
#define ll long long
#define ull unsigned long long
 
int main(){
  cin.tie(0);
  ios::sync_with_stdio(false);
 
  int n, m;
  cin >> n >> m;
 
  int thre[n];
  REP(i, n) thre[i] = i+1;
 
  int writecheck[m];
  REP(i, m) cin >> writecheck[i];
 
  int res[n];
  int counter = 0;
  RREP(i, m) {
      int current = writecheck[i];
      if(thre[current-1] > 0) {
          res[counter++] = current;
          thre[current-1] = 0;
      }
  }
 
  REP(i, n) {
      if(thre[i] > 0) {
          res[counter++] = thre[i];
      }
  }
 
  REP(i, n) {
      cout << res[i] << endl;
  }
 
  return 0;
}