CODE FESTIVAL 2016 qual A

Submission #1421121

Source codeソースコード

#include<string>
#include<deque>
#include<queue>
#include<vector>
#include<algorithm>
#include<iostream>
#include<set>
#include<cmath>
#include<tuple>
#include<chrono>
#include<functional>
#include<random>
#include<unordered_set>
using namespace std;
typedef long long int llint;
#define mp make_pair
#define mt make_tuple
#define pub push_back
#define puf push_front
#define pob pop_back
#define pof pop_front
#define fir first
#define sec second
#define res resize
#define ins insert
#define era erase
const int mod=1000000007;
const int big=1e9+10;
const long double pai=3.141592653589793238462643383279;
template <class T,class U>void mineq(T& a,U b){if(a>b){a=b;}}
template <class T,class U>void maxeq(T& a,U b){if(a<b){a=b;}}
llint gcd(llint a,llint b){if(b==0){return a;}return gcd(b,a%b);}//a>b
llint lcm(llint a,llint b){return (a/gcd(max(a,b),min(a,b)))*b;}
int main(void){
	int n,m,q,i,j,zyu=1,nai=0;cin>>n>>m>>q;
	vector<int>ban(q);//入力 番号
	vector<deque<int>>numlis(m+1);//どこに番号があるのだろう?
	multiset<int>las;//最後に番号入れたのいつ?
	vector<bool>mita(m+1);
	for(i=0;i<n;i++){las.ins(big);}
	for(i=0;i<q;i++){
		int in;cin>>in;
		ban[i]=in;
		numlis[in].puf(i);
	}
	for(i=q-1;i>=0;i--){
		int no=ban[i];
		if(mita[no]){continue;}//skipped
		bool mincan=false;
		while(mita[zyu]){zyu++;}
		mita[no]=true;
		mincan=(zyu==no);
		vector<int>iti;
		for(j=0;j<n;j++){
			if(j>=numlis[no].size()){break;}
			auto it=las.lower_bound(numlis[no][j]);
			if(it==las.end()){break;}
			iti.pub(*it);
			las.erase(it);
		}
		if(j<n&&(!mincan)){cout<<"No"<<endl;return 0;}
		for(;j<n-nai;j++){
			auto it=las.lower_bound(-1);
			iti.pub(-999);
			las.erase(it);
			nai++;
		}
		while(iti.size()!=0){las.ins(iti.back());iti.pob();}
		//cout<<endl<<"de i="<<i;
		//for(auto it=las.begin();it!=las.end();it++){cout<<" "<<(*it);}
	}
	cout<<"Yes"<<endl;
	return 0;
}

Submission

Task問題 A - CODEFESTIVAL 2016
User nameユーザ名 WA_TLE
Created time投稿日時
Language言語 C++14 (GCC 5.4.1)
Status状態 RE
Score得点 0
Source lengthソースコード長 1973 Byte
File nameファイル名
Exec time実行時間 ms
Memory usageメモリ使用量 -

Test case

Set

Set name Score得点 / Max score Cases
Sample - 0_00.txt,0_01.txt,0_02.txt
All 0 / 100 0_00.txt,0_01.txt,0_02.txt,1_00.txt,1_01.txt,1_02.txt

Test case

Case name Status状態 Exec time実行時間 Memory usageメモリ使用量
0_00.txt RE
0_01.txt RE
0_02.txt RE
1_00.txt RE
1_01.txt RE
1_02.txt RE