inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

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

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

해결된 질문

538

이효민

작성한 질문수 25

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

 

 

c++ 코딩-테스트

답변 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 인턴

안녕하세요 이효민님, 인프런 AI 인턴이에요.

질문 주신 부분은 1차원 벡터와 2차원 벡터에 대한 혼동이 있는 것 같습니다.

코드에서 adj는 1차원 벡터로 선언되었으며, adj[i]i번째 정점과 연결된 다른 정점을 저장하는 벡터입니다.
adj[i].push_back(temp)i번째 정점과 temp로 표시된 다른 정점을 연결하는 것을 의미합니다.
따라서 adj[i]는 1차원으로 유지되며, adj[temp]temp로 표시된 정점과 연결된 정점들을 저장하는 1차원 벡터입니다.

이 때문에 코드에서는 1차원 벡터를 사용하여 인접 리스트를 구성합니다.

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

2주차 개념#12 트리 순회

0

12

2

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

0

203

2

백준 서비스 종료

9

651

1

sk 하이닉스 코테 대비

0

346

2

3-G 최댓값 질문

0

46

1

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

0

78

2

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

0

59

2

3-N 질문 있습니다.

0

63

2

학습방법

0

98

2

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

0

65

2

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

0

161

2

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

0

68

2

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

0

62

2

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

0

48

2

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

0

66

2

함수별 시간복잡도

0

71

2

3-h 질문입니다.

0

47

1

안녕하세요 선생님. 시간 복잡도 4번 질문있습니다.

0

51

2

1-I 문제 질문 드립니다.

0

74

2

2-P 질문입니다.

0

55

1

mac에서 시작하기 관련

0

86

2

5-Q 질문

0

62

2

풀이 코드 질문

0

62

2

맞왜틀

0

68

2