inflearn logo
강의

Course

Instructor

10-Week Completion C++ Coding Test | Algorithm Coding Test

6-B

6-B 누적합에서 보는 이득이 클까요?

323

mch473700

16 asked

0

http://boj.kr/e1c4b7529c7d4925bb95b0e38d7aec56


처음에는 1~10억으로 이분탐색을 했었는데요

시간초과가 나서 배열에 있는 값들을 더하고 확인하는 시간이 오래 걸리나 싶어서 누적합으로 해서 풀었는데 큰 차이는 없었습니다.

 

못풀어서 결국 강의 봤는데if (mx > mid) return false; 부분을 보고 감탄을 금치 못했는데요..

누적합으로 바꿨을 때 답이 아니었던게 좀 충격이었던지라

누적합을 이런 용도로 사용하는 것이 아닌가?라는

의문이 들기도 하고 .. 누적합의 퍼포먼스를 최대로 낼 수 있는 문제가 막 떠오르지가 않아서 잘 이해하고 있는지 의문이 들어 글 남겨봅니다 ㅜㅜ

c++ 코딩-테스트

Answer 2

0

mch473700

답변 감사합니다 고민 많이 해보겠습니다

0

kundol

안녕하세요 mch님 ㅎㅎ

시간초과가 나서 배열에 있는 값들을 더하고 확인하는 시간이 오래 걸리나 싶어서 누적합으로 해서 풀었는데 큰 차이는 없었습니다.

>> 괜찮은 생각입니다. 누적합 잘하셨어요 ㅎㅎ

 

다만...

	while (i<=n)
	{
		for (; a[i] - a[l] <= size; ++i)
		{
			if (i > n) break;
		}

코드를 보시면 중첩루프입니다. 즉, 누적합을 사용하기 위해서 i, l 범위를 정해야 하는 코스트도 들기 때문에 그렇게 차이는 안나는 것 같습니다.

 

누적합을 이런 용도로 사용하는 것이 아닌가?

>> 아니요. 시도자체는 괜찮습니다. 생각하시는 플로우도 맞습니다. 그러나 중첩for문이 생기므로 -> 그렇게 까지는 효율적이지 않구나 하고 넘어가시면 됩니다.

이렇게 생각하고 -> 어? 별로인거 같네 : 이렇게 빠르게 생각하시는 것 자체가 알고리즘 실력이라고 보시면 되고. 잘하셨습니다. ㅎㅎ

 

 

또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.

코딩 살구 클럽 로그인 문제

0

25

1

2-J 채점관련 질문

0

25

3

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

0

45

1

살구클럽 아이디 없음 문제

0

55

1

1-O 코딩살구클럽 채점관련 질문

0

45

2

히든 테스트 케이스가 사라졌습니다

0

42

1

채점서버 혹시 다른 언어 지원도 가능하게 해주실 수 있나요

1

54

2

살구 클럽 채점 관련 문의(테스트 케이스)

0

52

2

1-H 문제 채점하기 오류

0

47

3

코딩살구클럽 2주차 2-L 문제 채점하기 오류

0

42

2

살구 클럽 채점 관련 문의

0

55

2

코딩 살구 클럽 실전 세션

0

48

2

코딩살구클럽 채점 관련 질문

0

42

2

코딩살구클럽 컴파일에러

0

74

2

5-B

0

47

2

4 - A

0

51

2

코딩살구클럽 입장이 안됩니다

0

124

2

4-F 경우의 수 질문입니다.

0

53

2

코딩살구클럽 가입이 안됩니다.

0

119

2

살구 클럽에 대한 질문있습ㄴ디ㅏ

0

76

1

교안 158페이지 문의드립니다

0

53

2

코딩살구클럽 관련 건의사항

0

161

1

코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다

0

54

1

진행 방법 질문드립니다!

0

102

2