inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

4-F

성능 비교 관련해서 질문 있습니다.

86

문예찬

작성한 질문수 17

0

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

저는 공부할 때 제가 짠 코드랑 큰돌님이 짠 코드 그리고 채점현황에 있는 다른 사람코드를 보며 걸린 시간을 자주 비교해봅니다.

걸린 시간이 차이나는 건 해결방법의 시간복잡도의 차이가 있어서겠지만, 코드를 비교하다보면 꽤나 자주 문제를 푸는 방법이 비슷한데도 불구하고 걸린 시간 차이가 유의미해 보이는 경우가 있습니다.

예를 들면 4-F문제의 경우 큰돌님이 공유해주신 코드는 124ms걸렸습니다. (제가 다시 큰돌님 코드 그대로 다시 돌려봤을 때는 100ms 걸렸습니다.)

http://boj.kr/7943b7d08dcb4d30bec01eabbf160e77

그리고 제가 큰돌님 코드를 참고해서 다시 짠 코드는 24ms가 걸렸습니다.

http://boj.kr/e57959b67c14428ab1a14942f45f667e

큰돌님꺼 보고 짠거라 논리는 거의 똑같은데 4~5배 정도의 시간차이가 나서 꽤 유의미한 차이가 나는 것에 의문이 들었습니다.

하지만 제가 그 우의미한 시간 차이의 원인을 찾기는 힘들었습니다.

백준 테스트케이스의 구성에 따라서 같은 성능을 가진 두 코드라도 걸린 시간의 유의미한 시간 차이가 생길 수 있는 걸까요?

걸린 시간 차이가 왜 생겼는지 고민해보는 건 좋겠지만 이 정도의 코드 차이에 대해서 걸린 시간 차이가 왜 생겼는지 고민해보는 건 불필요할까요?

아니면 제가 생각히지 못하는 두 코드의 유의미한 성능에 영향을 주는 요소가 있을까요?

이런 비교를 하는데 너무 시간을 쓰는 건 아닐까 고민이 되기도 해서 질문드립니다.

감사합니다.

c++ 코딩-테스트

답변 1

0

큰돌

안녕하세요 예찬님 ㅎㅎ

노스텔지어의 수건같은 아름다운 질문이네요 ㅎㅎ

아니면 제가 생각히지 못하는 두 코드의 유의미한 성능에 영향을 주는 요소가 있을까요?

-> 제 코드는 매번 max로 비교합니다 + cnt 의 순서가 다릅니다.( 제껀 m -> 0, 예찬님껀 0 -> m) + 마지막으로 이부분이 제일 다릅니다.

// 제꺼 
if (index == 26) return count(mask); 

//예찬님
    if (cnt == k) {
        ans = max(ans, count(learnedChars));

제꺼는 26에 와서 계산을 하는데 예찬님꺼는 k개까지만 오면 계산을 하기 때문에 k개를 쓰고 -> 불필요하게 24, 25, 26.. 까지 가는 재귀함수 호출이 가지치기가 됩니다.

이 차이 때문에 성능차이가 나는 것입니다.

즉, 예찬님 코드가 제코드보다 좋습니다. ㅎㅎ

image.png

 

ㅎㅎ 많이 테스팅해봤습니다. :)

 

걸린 시간 차이가 왜 생겼는지 고민해보는 건 좋겠지만 이 정도의 코드 차이에 대해서 걸린 시간 차이가 왜 생겼는지 고민해보는 건 불필요할까요?

-> 100ms정도면 큰차이라 생각해보는 건 당연합니다. ㅎㅎ 훌륭합니다.

0

문예찬

아 그러네요,, 이해됐습니다. 정성스레 답해주셔서 감사드립니다.

이런 비슷한 고민을 되게 자주 하게 되는데 결론을 못 내리는 경우가 많아서 시간을 많이 쓰고는 했습니다.

항상 친절한 답변 감사드립니다..!!

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

0

31

2

2주차 개념#12 트리 순회

0

21

2

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

0

246

2

백준 서비스 종료

9

789

1

sk 하이닉스 코테 대비

0

361

2

3-G 최댓값 질문

0

50

1

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

0

82

2

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

0

62

2

3-N 질문 있습니다.

0

66

2

학습방법

0

100

2

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

0

66

2

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

0

166

2

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

0

69

2

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

0

64

2

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

0

50

2

조합 재귀 풀이 확인 해주시면 감사하겠습니다.

0

67

2

함수별 시간복잡도

0

72

2

3-h 질문입니다.

0

49

1

안녕하세요 선생님. 시간 복잡도 4번 질문있습니다.

0

52

2

1-I 문제 질문 드립니다.

0

76

2

2-P 질문입니다.

0

56

1

mac에서 시작하기 관련

0

90

2

5-Q 질문

0

63

2

풀이 코드 질문

0

64

2