名もなき未知

エンジニアリングとか、日常とかそういうのをまとめる場所。アクセス解析のためGAを利用、Googleに情報を送信しています。商品紹介のためAmazonアフィリエイトを利用、Amazonに情報を送信しています。記事に関しては私が書いていない引用文を除いて自由にご利用ください。

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;
}