inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

2-S

2-S 질문있습니다.

113

이상민

작성한 질문수 27

0

안녕하세요 큰돌님 강의 잘 보고 있습니다.

 

혼자 문제를 풀때 dfs와 dp를 섞어서 다음과 같이 풀었습니다.

 

http://boj.kr/1502bc54c9eb4d5ea406fd47713ab8e5

dp를 섞어 각 노드당 한번씩만 방문하게 하여 입력, 로직 수행, 출력 모두 합쳐도 최대 O(2n+m)이라는 생각이 드는데 시간 초과가 나옵니다. 혹시 제가 놓치고 있는 부분이 있을까요?

 

c++ 코딩-테스트

답변 1

1

큰돌

안녕하세요 상민님 ㅎㅎ

반례 찾느라 시간이 걸렸습니다 ㅎㅎ

 

시간초과가 아니라 로직상 틀렸습니다.

반례는 다음과 같습니다.

12 13
2 1
3 2
4 3
5 4
1 5
6 5
7 6
8 7
9 8
5 9
10 9
11 10
12 11

 

답 : 1 2 3 4 5 6 7 8 9

상민님 코드 : 1

 

스크린샷 2025-01-15 오후 11.13.07.png.webp

참고로 위의 반례는 앞의 그림과 같은 그래프를 의미합니다.

 

감사합니다.

0

이상민

사이클을 고려하지 못해서 틀렸었네요! 감사합니다!

추가로 궁금한점이 있는데 큰돌님께서는 강의에서 시간복잡도가 보통 O(10,000,000) 까지는 괜찮다고 하셨던것이 기억납니다.

이때 만약 그래프가 1->2->3-> ... -> 10000 이렇게 되어 있는 상황에서 특정 노드마다 그래프 탐색을 수행하면 시간복잡도가 약 O(50,000,000)이 됩니다.

이는 시간 복잡도가 O(1000만)을 넘어감에도 불구하고 하나의 재귀 함수당 로직이 많지 않아서 괜찮은건가요? 아니면 일반적으로 시간복잡도가 O(1억) ≒ 1초 이고 C++은 다른 언어에 비해 실행속도가 빠르므로 시간초과가 나지 않는걸까요?

1

큰돌

시간복잡도 1억은 될 때도 많습니다.

해당 부분은 알고리즘 개념 교안도 참고부탁드립니다. ㅎㅎ

스크린샷 2025-01-17 오전 5.59.20.png.webp

 

감사합니다.

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

0

1

1

문제를 고민하는 시간 관련

0

15

2

코딩살구클럽

0

28

2

코딩살구클럽 문의

0

30

2

코딩살구클럽 승인

0

33

2

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

0

32

2

3-F 채점 관련 질문

0

30

1

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

0

32

2

코딩살구클럽 승인

0

43

2

코딩살구클럽승인

0

39

3

코딩살구클럽 승인

0

51

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

64

2

코딩살구클럽 로그인문제

0

79

3

코딩 살구 클럽 로그인 문제

0

85

2

2-J 채점관련 질문

0

67

3

코딩 살구 클럽 Python 지원 가능 여부

0

77

1

살구클럽 아이디 없음 문제

0

76

1