해결된 질문
작성
·
168
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로 봐도 되는지 궁금합니다.
답변 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
안녕하세요, 인프런 AI 인턴이에요.
vector
v[10001]은 크기가 10001인 1차원 vector 배열을 선언한 것이에요.
따라서 각 b(신뢰받는 컴퓨터)에 해당하는 vector
위 코드에서 v[b].push_back(a);는 b(신뢰받는 컴퓨터)에 해당하는 1차원 배열에 a(신뢰하는 컴퓨터)를 추가하는 것이에요.
즉, v[b]는 b(신뢰받는 컴퓨터)에 신뢰하는 컴퓨터들 a를 담고 있는 1차원 배열로 볼 수 있습니다.
하지만, 수도 코드로 표현하신 [b : [a1, a2, a3], b2 : [a1, a2, a3]]와 같은 형태는 vector
만약 수도 코드와 같은 형태를 구현하고 싶으시다면, 다른 자료 구조를 사용해야 할 것 같아요.
처음에 vector
추가로, 강의 교안에는 vector
2차원 배열로 사용하고 싶다면, 다른 방식으로 선언하셔야 합니다.
더 궁금한 사항이 있으시면 언제든지 물어보세요.
그러면 어떻게 여러 신뢰 관계들을 하나의 인덱스에다가 담을 수 있는 것인가요? 예를 들어서 1번 컴퓨터가 2, 3, 으로부터 신뢰받는다고 하면
v[1] = [2,3] 이렇게 int가 아니라 array를 해당 index에 넣을 수 있어야 하는게 아닌가요?... 신뢰관계가 1:1이 아니라 n:n 이기 때문에 여전히 의문이 있습니다 .
vector<int> v[1001] 가 아래 꼴이 가능한건가요? cout 해보니깐 아래처럼 되어있는것 같긴 해서요.
[[2,3],[....],[....]]
역시 직접달아주시니 바로 이해가 되네요. 감사합니다^^