작성
·
415
답변 1
4
안녕하세요 배고픔님ㅎㅎ
훌륭하십니다.. ㅎㅎ 제 코드의 반례 그리고 그 반례의 이유까지..
네 맞습니다.
(-1,000,000,000 ≤ Ai ≤ 1,000,000,000) 이외에 값으로 초기화해야 되지 않나요?
>> 그 외의 값으로 초기화를 하는게 맞습니다.
해당 코드는 다음과 같이 수정될 예정이며 해당 강의 또한 오늘내로 수정하도록 하겠습니다.
#include <bits/stdc++.h>
using namespace std;
int n, lis[1000004], len, num;
pair<int, int> ans[1000004];
stack<int> stk;
const int INF = 1e9 + 4;
int main() {
fill(lis, lis + 1000004, INF);
scanf("%d", &n);
for (int i = 0; i < n; i++){
scanf("%d", &num);
auto lowerPos = lower_bound(lis, lis + len, num);
int _pos = (int)(lower_bound(lis, lis + len, num) - lis);
if(*lowerPos == INF) len++;
*lowerPos = num;
ans[i].first = _pos;
ans[i].second = num;
}
printf("%d\n", len);
for(int i = n - 1; i >= 0; i--){
if(ans[i].first == len - 1){
stk.push(ans[i].second); len--;
}
}
while(stk.size()){
printf("%d\n", stk.top());stk.pop();
}
return 0;
}
제 틀린점을 찾아주셔서 정말 감사드립니다.
감사합니다.
강사 큰돌 올림.
좋은 문제와 해설 덕분에 많은 도움을 받고 있습니다 감사합니다.