6-K 질문있습니다
168
작성한 질문수 10
- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 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;
}
답변 1
0
안녕하세요 ㅎㅎ
begin은 변하지 않습니다. it가 변경되서 그렇습니다. (end일 때...)
if (it == LIS.end()) LIS.push_back(A[i]);
else *it = A[i];
cout << *LIS.begin() << "\n";이렇게 찍어보면 같은 값이 찍히게 됩니다.
감사합니다.
코살구 1주차 1940번 문제 조건과 프라이빗 테스트 불일치 문의
0
4
1
문제를 고민하는 시간 관련
0
15
2
코딩살구클럽
0
28
2
코딩살구클럽 문의
0
31
2
코딩살구클럽 승인
0
33
2
DP 경우의 수 설명이 이해가 되지 않습니다.
0
32
2
3-F 채점 관련 질문
0
30
1
BFS, DFS 활용이 되는 상황에서의 방향성
0
32
2
코딩살구클럽 승인
0
43
2
코딩살구클럽승인
0
39
3
코딩살구클럽 승인
0
51
2
3-D 관련 질문
0
35
2
코살구 회원가입 문의
0
45
2
코살구 로그인 문제
0
65
2
3-A 문제 풀이 관련 질문
0
56
3
2-O 질문 있습니다
0
38
2
2-T 문제에 관한 질문
0
40
2
코딩 살구 클럽 접속 및 사용방법 문의
0
63
2
안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~
0
64
2
코딩살구클럽 로그인문제
0
79
3
코딩 살구 클럽 로그인 문제
0
85
2
2-J 채점관련 질문
0
67
3
코딩 살구 클럽 Python 지원 가능 여부
0
77
1
살구클럽 아이디 없음 문제
0
76
1





