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

이효민님의 프로필 이미지
이효민

작성한 질문수

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

4-C와 다양한 타입의 함수

4-c_17471 1차원 벡터 2차원 벡터

해결된 질문

작성

·

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차원 배열이 되는 것이죠.

 

그림

>> 우엉.. 너무 잘 그리셨어요. 딱 그겁니다.

 

저도 한번 그려봤는데요. image

이렇게 되는 것입니다. 처음 비어있는 배열로 이루어진 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차원 벡터를 사용하여 인접 리스트를 구성합니다.

강의와 예시 코드를 참고해주셔서 공부에 도움이 될 것입니다. 재밌고 유익한 공부 되시기를 바랍니다! 감사합니다.

이효민님의 프로필 이미지
이효민

작성한 질문수

질문하기