inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

2-S

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

해결된 질문

222

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],[....],[....]]

코딩 살구 클럽 컴파일 에러

0

4

1

추천 문제

0

7

1

코딩살구클럽 승인

0

9

1

코살구 1주차 1940번 문제 조건과 프라이빗 테스트 불일치 문의

0

21

2

문제를 고민하는 시간 관련

0

26

2

코딩살구클럽

0

38

2

코딩살구클럽 문의

0

37

2

코딩살구클럽 승인

0

35

2

DP 경우의 수 설명이 이해가 되지 않습니다.

0

33

2

3-F 채점 관련 질문

0

31

1

BFS, DFS 활용이 되는 상황에서의 방향성

0

33

2

코딩살구클럽 승인

0

45

2

코딩살구클럽승인

0

39

3

코딩살구클럽 승인

0

54

2

3-D 관련 질문

0

35

2

코살구 회원가입 문의

0

45

2

코살구 로그인 문제

0

65

2

3-A 문제 풀이 관련 질문

0

56

3

2-O 질문 있습니다

0

38

2

2-T 문제에 관한 질문

0

40

2

코딩 살구 클럽 접속 및 사용방법 문의

0

63

2

안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~

0

67

2

코딩살구클럽 로그인문제

0

85

3

코딩 살구 클럽 로그인 문제

0

86

2