inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

6-K

6-K 질문있습니다

163

윽쓰욱스

작성한 질문수 10

0

- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.

 

안녕하세요. 강의 잘 듣고 있습니다.

 

강의 풀이 참고하여 코드 작성하였는데.

ans.push_back({it-LIS.begin(), A[i]});

라인의 위치에 따라 "it-LIS.begin()"의 값이 쓰레기값일 때도 있고 그래서.., 현상의 이유가 궁금합니다.

 

ans.push_back()을 뒤에 위치시켰을때, pos_ 값이 쓰레기값이 되는 이유 질문드려요.

 

그 이유로,

LIS.push_back(A[i]); 가 수행되고 나면 LIS.begin()의 주소값이 변경되는 것으로 생각되는데, 맞을까요?

 

 

 

 

전체 코드>>

#include <bits/stdc++.h>

using namespace std;

int N;
vector<int> A;
vector<int> LIS, Ret;
int len;

vector<pair<int, int>> ans;

int main(){
    cin.tie(NULL);
    cout.tie(NULL);
    ios_base::sync_with_stdio(false);

    cin >> N ;
    A = vector<int>(N,0);
    for(int i =0 ; i < N ; ++i) cin >> A[i];

    for(int i = 0 ; i < N ; ++i){
        auto it = lower_bound(LIS.begin(), LIS.end(), A[i]);

        ans.push_back({it-LIS.begin(), A[i]});
        /* 현재 위치에서 push_back 하였을 떄: 
          >> ans 배열에 담긴 값:
          ans = {
                    {0, 10}
                    {1, 20}
                    {0, 10}
                    {2, 30}
                    {1, 20}
                    {3, 50}
                }
        */

        if (it == LIS.end()) LIS.push_back(A[i]);
        else *it = A[i];

        /* 아래 위치에서 push_back 하였을 떄(주석): 
          ans.push_back({it-LIS.begin(), A[i]});
          >> ans 배열에 담긴 값:
          ans = {
                    {-1405095968, 10}
                    {-7, 20}
                    {0, 10}
                    {10, 30}
                    {1, 20}
                    {3, 50}
                }
        */
    }   


    cout << "디버깅" << endl;
    for(auto a : ans) cout << a.first << " " << a.second << endl;
    cout << endl;

    int len = LIS.size();
    cout << len << endl;

    // 배열을 trace 
    for(int i = N-1 ; i >= 0 ; --i){
        if (ans[i].first == len-1){
            Ret.push_back(ans[i].second);
            len--;
        }
    }

    reverse(Ret.begin(), Ret.end());
    for(auto r: Ret) cout << r << " ";
    cout << endl;

    return 0;
}

c++ 코딩-테스트

답변 1

0

큰돌

안녕하세요 ㅎㅎ

begin은 변하지 않습니다. it가 변경되서 그렇습니다. (end일 때...)


        if (it == LIS.end()) LIS.push_back(A[i]);
        else *it = A[i];
        cout << *LIS.begin() << "\n";

이렇게 찍어보면 같은 값이 찍히게 됩니다.

 

감사합니다.

4-F 경우의 수 질문입니다.

0

19

2

코딩살구클럽 가입이 안됩니다.

0

43

2

살구 클럽에 대한 질문있습ㄴ디ㅏ

0

38

1

교안 158페이지 문의드립니다

0

37

2

코딩살구클럽 관련 건의사항

0

89

1

코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다

0

38

1

진행 방법 질문드립니다!

0

71

2

2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.

0

61

2

2주차 개념#12 트리 순회

0

32

2

백준사이트가 종료된다고 합니다.

0

299

2

백준 서비스 종료

9

912

1

sk 하이닉스 코테 대비

0

377

2

3-G 최댓값 질문

0

52

1

모듈러 연산 값이 10이 아닌 경우도 있지 않나요?

0

84

2

3-I 코드 질문드립니다.

0

63

2

3-N 질문 있습니다.

0

68

2

학습방법

0

103

2

4-H 질문 있습니다 (코드 리뷰)

0

67

2

코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.

0

178

2

2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.

0

70

2

2주차 개념 #4-2. 인접행렬 질문있습니다.

0

65

2

1-A 문제풀이 후 궁금한 점이 생겨서 질문드립니다.

0

52

2

조합 재귀 풀이 확인 해주시면 감사하겠습니다.

0

69

2

함수별 시간복잡도

0

75

2