inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

2-S

문제 2-S -> vector[]가 이해가 안되요..

해결된 질문

208

Kanto(칸토)

작성한 질문수 4

1

실은 제가 파이썬으로 구현을 해보려고 해서 질문을 남겨요.

vector<int> v[10001];
v[b].push_back(a);

이게 2D array라고 생각하면 될까요..

문제의 자료를 담으려면 수도 코드로

[b : [a1, a2, a3], b2 : [a1, a2, a3]] 이렇게 들어가는게 맞을텐데 , 그럼 위에서 vector<int> v[10001]; 으로 선언한 부분이 각 b (신뢰받는 컴퓨터) 에 대해서 여러 a 들(신뢰하는 컴퓨터)를 담는 위 수도 코드를 구현할 수 있는 자료구조형인걸까요?

교안을 찾아봐도 모두 vector<int> v; 로만 선언되어서 1-d array로만 나오는 것 같어서 위 구조 v[10001] 를2-d array로 봐도 되는지 궁금합니다.

c++ 코딩-테스트

답변 2

0

큰돌

안녕하세요 칸토님 ㅎㅎ

이게 2D array라고 생각하면 될까요..

>> 네 맞습니다.

 

문제의 자료를 담으려면 수도 코드로

[b : [a1, a2, a3], b2 : [a1, a2, a3]] 이렇게 들어가는게 맞을텐데 , 그럼 위에서 vector<int> v[10001]; 으로 선언한 부분이 각 b (신뢰받는 컴퓨터) 에 대해서 여러 a 들(신뢰하는 컴퓨터)를 담는 위 수도 코드를 구현할 수 있는 자료구조형인걸까요?

>> 네 맞습니다. 예를 들어 B1에 대해 A1, A2, A3가 신뢰가 형성이 되었다면

V[B1] = {A1, A2, A3} 이렇게 나타낼 수 있습니다.

교안을 찾아봐도 모두 vector<int> v; 로만 선언되어서 1-d array로만 나오는 것 같어서 위 구조 v[10001] 를2-d array로 봐도 되는지 궁금합니다.

>> 교안 내의 vector를 이용한 2차원 배열을 만드는 3가지 방법입니다.  를 참고 부탁드립니다.

또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.

0

Kanto(칸토)

역시 직접달아주시니 바로 이해가 되네요. 감사합니다^^

0

인프런 AI 인턴

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

vector v[10001];은 2차원 배열이 아니라 1차원 배열이에요.
v[10001]은 크기가 10001인 1차원 vector 배열을 선언한 것이에요.
따라서 각 b(신뢰받는 컴퓨터)에 해당하는 vector v[b]는 1차원 배열의 하나의 요소(인덱스)에 해당하는 것이에요.

위 코드에서 v[b].push_back(a);는 b(신뢰받는 컴퓨터)에 해당하는 1차원 배열에 a(신뢰하는 컴퓨터)를 추가하는 것이에요.
즉, v[b]는 b(신뢰받는 컴퓨터)에 신뢰하는 컴퓨터들 a를 담고 있는 1차원 배열로 볼 수 있습니다.

하지만, 수도 코드로 표현하신 [b : [a1, a2, a3], b2 : [a1, a2, a3]]와 같은 형태는 vector v[10001];으로는 직접적으로 표현할 수 없어요.
만약 수도 코드와 같은 형태를 구현하고 싶으시다면, 다른 자료 구조를 사용해야 할 것 같아요.

처음에 vector v[10001];로 선언한 것은 각각의 b(신뢰받는 컴퓨터)에 대해 1차원 vector를 사용하여 여러 a(신뢰하는 컴퓨터)를 관리하는 것을 의도한 것이었습니다.

추가로, 강의 교안에는 vector v;로만 선언되어 있는데, v[10001]를 2차원 배열로 보는 것은 올바르지 않아요.
2차원 배열로 사용하고 싶다면, 다른 방식으로 선언하셔야 합니다.

더 궁금한 사항이 있으시면 언제든지 물어보세요.

0

Kanto(칸토)

그러면 어떻게 여러 신뢰 관계들을 하나의 인덱스에다가 담을 수 있는 것인가요? 예를 들어서 1번 컴퓨터가 2, 3, 으로부터 신뢰받는다고 하면

v[1] = [2,3] 이렇게 int가 아니라 array를 해당 index에 넣을 수 있어야 하는게 아닌가요?... 신뢰관계가 1:1이 아니라 n:n 이기 때문에 여전히 의문이 있습니다 .

vector<int> v[1001] 가 아래 꼴이 가능한건가요? cout 해보니깐 아래처럼 되어있는것 같긴 해서요.

[[2,3],[....],[....]]

4 - A

0

24

2

코딩살구클럽 입장이 안됩니다

0

62

2

4-F 경우의 수 질문입니다.

0

32

2

코딩살구클럽 가입이 안됩니다.

0

75

2

살구 클럽에 대한 질문있습ㄴ디ㅏ

0

54

1

교안 158페이지 문의드립니다

0

44

2

코딩살구클럽 관련 건의사항

0

115

1

코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다

0

44

1

진행 방법 질문드립니다!

0

81

2

2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.

0

63

2

2주차 개념#12 트리 순회

0

32

2

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

0

316

2

백준 서비스 종료

9

950

1

sk 하이닉스 코테 대비

0

385

2

3-G 최댓값 질문

0

54

1

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

0

84

2

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

0

65

2

3-N 질문 있습니다.

0

68

2

학습방법

0

105

2

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

0

69

2

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

0

183

2

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

0

72

2

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

0

65

2

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

0

53

2