4-c_17471 1차원 벡터 2차원 벡터
안녕하세요 큰돌님 항상 좋은 강의 감사합니다. 비트 마스킹 문제가 너무 어렵네요...ㅎㅎ 열심히 연습해야겠습니다.
질문은 다름이 아니라 간선 정보를 입력 받을 때 1차원 벡터 adj를 선언하셨는데 adj[i].push_back(temp); 이런 형태로 push 하면 2차원 벡터로 되는 것 아닌가요?
부분 코드
vector<int> adj[11];
...
int main{
for(int i=1; i<=n; i++){
cin >> m;
for(int j=0; j<m; j++){
cin >>temp;
adj[i].push_back(temp); // <- 여기 이 부분 2차원 벡터여야 가능한거 아닌가요?
adj[temp].push_back(i);
}
}
...
제가 생각한 1차원 벡터 2차원 벡터는 아래 그림과 같습니다.
아 그리고 제 그림 좋게 봐주셔서 감사합니다.ㅎㅎ 이해하는데에는 큰돌님 말씀처럼 직접 그리는 것 만큼 좋은게 없더라구요
혹시 몰라 전체 코드도 남깁니다!
http://boj.kr/9fea383a1aba4c2ca268cf51acc08257
답변 3
1
안녕하세요 효민님 ㅎㅎ
질문은 다름이 아니라 간선 정보를 입력 받을 때 1차원 벡터 adj를 선언하셨는데 adj[i].push_back(temp); 이런 형태로 push 하면 2차원 벡터로 되는 것 아닌가요?
>> 네 맞습니다. 2차원 벡터가 됩니다.
vector<int> adj[11];
>> 이 의미 자체가 vector<int>를 11개를 만든다는 의미입니다. 1차원 배열 11개를 만드니 당연히 2차원 배열이 되는 것이죠.
그림
>> 우엉.. 너무 잘 그리셨어요. 딱 그겁니다.
저도 한번 그려봤는데요. 
이렇게 되는 것입니다. 처음 비어있는 배열로 이루어진 2차원 배열이 만들어집니다. 거기서 1, 2, 3을 넣고 3을 넣게 되면 저런식으로 조금은 꽉찬 2차원배열이 완성되는 것이죠. ㅎㅎ
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
0
안녕하세요 이효민님, 인프런 AI 인턴이에요.
질문 주신 부분은 1차원 벡터와 2차원 벡터에 대한 혼동이 있는 것 같습니다.
코드에서 adj는 1차원 벡터로 선언되었으며, adj[i]는 i번째 정점과 연결된 다른 정점을 저장하는 벡터입니다.
adj[i].push_back(temp)는 i번째 정점과 temp로 표시된 다른 정점을 연결하는 것을 의미합니다.
따라서 adj[i]는 1차원으로 유지되며, adj[temp]는 temp로 표시된 정점과 연결된 정점들을 저장하는 1차원 벡터입니다.
이 때문에 코드에서는 1차원 벡터를 사용하여 인접 리스트를 구성합니다.
강의와 예시 코드를 참고해주셔서 공부에 도움이 될 것입니다. 재밌고 유익한 공부 되시기를 바랍니다! 감사합니다.
DP 경우의 수 설명이 이해가 되지 않습니다.
0
10
1
3-F 채점 관련 질문
0
15
1
BFS, DFS 활용이 되는 상황에서의 방향성
0
20
2
코딩살구클럽 승인
0
28
2
코딩살구클럽승인
0
22
3
코딩살구클럽 승인
0
43
2
3-D 관련 질문
0
33
2
코살구 회원가입 문의
0
40
2
코살구 로그인 문제
0
61
2
3-A 문제 풀이 관련 질문
0
52
3
2-O 질문 있습니다
0
38
2
2-T 문제에 관한 질문
0
40
2
코딩 살구 클럽 접속 및 사용방법 문의
0
59
2
안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~
0
64
2
코딩살구클럽 로그인문제
0
75
3
코딩 살구 클럽 로그인 문제
0
79
2
2-J 채점관련 질문
0
65
3
코딩 살구 클럽 Python 지원 가능 여부
0
77
1
살구클럽 아이디 없음 문제
0
76
1
1-O 코딩살구클럽 채점관련 질문
0
60
2
히든 테스트 케이스가 사라졌습니다
0
57
1
채점서버 혹시 다른 언어 지원도 가능하게 해주실 수 있나요
1
74
2
살구 클럽 채점 관련 문의(테스트 케이스)
0
66
2
1-H 문제 채점하기 오류
0
58
3





