인프런 커뮤니티 질문&답변

배고픔님의 프로필 이미지
배고픔

작성한 질문수

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

6-K

6-K번 반례가 있습니다

작성

·

415

1

 

input:

2

0 -1

정상적인 output은
1
-1

선생님 코드의 output은
2

아마 입력 받는 수열중에 값이 0이 나올 때 len의 값이 증가해서 생기는 일 같은데, 먼저 lis배열을

(-1,000,000,000 ≤ Ai ≤ 1,000,000,000) 이외에 값으로 초기화해야 되지 않나요?

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

제 틀린점을 찾아주셔서 정말 감사드립니다.

 

감사합니다.

강사 큰돌 올림.

배고픔님의 프로필 이미지
배고픔
질문자

좋은 문제와 해설 덕분에 많은 도움을 받고 있습니다 감사합니다.

배고픔님의 프로필 이미지
배고픔

작성한 질문수

질문하기