inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

[필독] 질문하는 방법

2-R 1068 트리 메모리 초과

382

박현우

작성한 질문수 2

0

https://www.acmicpc.net/source/share/56756751bd5f416c9db6d47968b51772

노드수가 많아봤자 50개인데 메모리초과가 나는 이유를 모르겠습니다.

코드 자체가 효율적이지 못해도 틀린접근은 아닌 것 같은데 ㅠㅠ

코테 준비 같이 해요! C++

답변 1

0

큰돌

안녕하세요 현우님. ㅎㅎ

저도 이 코드를 몇번 돌려봤고 처음에는 pair<vector 이게 그렇게 메모리를 잡아먹나? 이런 생각을 했고 실제로도 많이 찾아봤는데요. vector는 배열에 비해 메모리를 조금은 많이 잡아먹는 것뿐이지 그렇게 크진 않습니다.

그렇다면 왜 메모리 초과가 뜰까요?

이건 그냥 틀린 코드라 그런게 나오는 겁니다. (UB라고 보시면됩니다. / 틀린 코드이기때문에 메모리초과든 시간초과든 나올 수가 있어요.)

첫째 줄에 트리의 노드의 개수 N이 주어진다. N은 50보다 작거나 같은 자연수이다. 둘째 줄에는 0번 노드부터 N-1번 노드까지, 각 노드의 부모가 주어진다. 만약 부모가 없다면 (루트) -1이 주어진다. 셋째 줄에는 지울 노드의 번호가 주어진다.

이게 문제의 지문인데요.

cin >> parent; // -1을 버리기 위해 읽음

현우님의 코드는 첫번째가 무조건 -1이 오고 거기에 따른 로직이 강제되어있는데 이런 말이 문제지문에 있나요?

감사합니다.

0

박현우

처음에 부모노드 없이 트리를 만드는게 불가능하니까 무조건 -1이 들어간다고 지레짐작했네요 다시풀어야겠습니다;

1-E질문입니다!

0

533

2

3-L 틀린 부분 피드백 부탁드립니다.

0

835

2

1-A문제 순열재귀함수 질문입니다.

0

396

1

1-A 일곱난쟁이문제입니다

0

470

1

문제 풀 때 방향성에 대해

0

810

1

맥에서 vs code로 실행 관련 질문입니다

0

530

1

17071번 메모리 초과

0

390

1

1-C질문입니다!

0

428

2

2-B BFS 시간초과질문

0

638

2

1-O 13번 라인

0

447

1

6-J 놀이공원 문제 질문

0

389

1

구현관련 질문

0

491

1

강의 교안

0

322

1

실력을 더 올리고나서 강의를 보는 것이 맞을까요?

0

550

1

안녕하세요! 재귀함수에 관해서 질문드립니다

0

540

1

1-K

0

481

2

3-G번 질문있습니다.

1

480

3

3-C 실행 시간 질문드립니다.

0

503

1

4-A 문제 풀이 질문있습니다.

0

601

2

비트마스킹 연산자 "1의 보수" 영문 표기법

0

441

1

격자탐색 문제에서 BFS 시간복잡도 질문드립니다.

0

349

1

3-O go 함수 질문 드립니다.

1

453

2

4-A 출력 질문

0

308

1

1주차 1-O 질문드립니다

0

266

1