해결된 질문
작성
·
401
0
안녕하세요 큰돌님 항상 좋은 강의 감사합니다. 비트 마스킹 문제가 너무 어렵네요...ㅎㅎ 열심히 연습해야겠습니다.
질문은 다름이 아니라 간선 정보를 입력 받을 때 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
0
안녕하세요 이효민님, 인프런 AI 인턴이에요.
질문 주신 부분은 1차원 벡터와 2차원 벡터에 대한 혼동이 있는 것 같습니다.
코드에서 adj
는 1차원 벡터로 선언되었으며, adj[i]
는 i
번째 정점과 연결된 다른 정점을 저장하는 벡터입니다.
adj[i].push_back(temp)
는 i
번째 정점과 temp
로 표시된 다른 정점을 연결하는 것을 의미합니다.
따라서 adj[i]
는 1차원으로 유지되며, adj[temp]
는 temp
로 표시된 정점과 연결된 정점들을 저장하는 1차원 벡터입니다.
이 때문에 코드에서는 1차원 벡터를 사용하여 인접 리스트를 구성합니다.
강의와 예시 코드를 참고해주셔서 공부에 도움이 될 것입니다. 재밌고 유익한 공부 되시기를 바랍니다! 감사합니다.