| # | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
|---|---|---|---|---|---|---|---|
| 1320747 | c4l | Hidden Sequence (info1cup18_hidden) | C++20 | 6 ms | 428 KiB |
#include <bits/stdc++.h>
using namespace std;
//#define ngu
#define check isSubsequence
#ifndef ngu
#include "grader.h"
#endif
#ifdef ngu
static int maxQ = 0;
static vector < int > theRealAnswer;
bool isSubsequence (vector < int > v)
{
if (v.size () > maxQ)
maxQ = v.size ();
int i = 0;
for (auto it : v)
{
while (i < theRealAnswer.size () && it != theRealAnswer[i]) i ++;
if (i == theRealAnswer.size ()) return 0;
i ++;
}
return 1;
}
#endif
vector<int> findSequence(int n)
{
if(n<=10){
int maxn = (1<<n);
for (int i = 0;i<maxn;++i){
vector<int> luu;
for (int j = 0;j<n;++j){
if(i & (1<<j))luu.push_back(1);
else luu.push_back(0);
}
if(isSubsequence(luu)){
return luu;
}
}
}else{
vector<int> luu;
bool c = false;
while(!c){
if(luu.size()==n)break;
luu.push_back(0);
if(!check(luu)){
luu.pop_back();
luu.push_back(1);
if(!check(luu)){
luu.pop_back();
c = true;
}
}
}
for (int i = 0;i<n;++i){
bool c = false;
while(!c){
if(luu.size()==n)break;
luu.insert(luu.begin()+i, 0);
if(!check(luu)){
luu.erase(luu.begin()+i);
luu.insert(luu.begin()+i, 1);
if(!check(luu)){
luu.erase(luu.begin()+i);
c = true;
}
}
}
}
return luu;
}
}
#ifdef ngu
int main ()
{
int n, x;
scanf ("%d", &n), maxQ = 0;
for (int i=1; i<=n; i++)
scanf ("%d", &x), theRealAnswer.push_back (x);
vector < int > ans = findSequence (n);
if (ans.size () != theRealAnswer.size ())
{
printf ("Different lengths\n");
for (auto it : ans)
printf ("%d ", it);
printf ("\n");
return 0;
}
for (int i=0; i<ans.size (); i++)
if (ans[i] != theRealAnswer[i])
{
printf ("WA position %d\n", i + 1);
for (auto it : ans)
printf ("%d ", it);
printf ("\n");
return 0;
}
printf ("Ok, biggest queried length %d\n", maxQ);
return 0;
}
#endif
컴파일 시 표준 에러 (stderr) 메시지
| # | Verdict | Execution time | Memory | Grader output |
|---|---|---|---|---|
| Fetching results... | ||||
| # | Verdict | Execution time | Memory | Grader output |
|---|---|---|---|---|
| Fetching results... | ||||
