inflearn logo
강의

講義

知識共有

10週間完成 C++ コーディングテスト | アルゴリズムコーディングテスト

6-B

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

326

mch473700

投稿した質問数 16

0

http://boj.kr/e1c4b7529c7d4925bb95b0e38d7aec56


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

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

 

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

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

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

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

c++ 코딩-테스트

回答 2

0

mch473700

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

0

kundol

안녕하세요 mch님 ㅎㅎ

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

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

 

다만...

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

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

 

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

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

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

 

 

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

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

감사합니다.

강사 큰돌 올림.

3-F 채점 관련 질문

0

6

0

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

0

12

2

코딩살구클럽 승인

0

18

2

코딩살구클럽승인

0

15

2

코딩살구클럽 승인

0

43

2

3-D 관련 질문

0

33

2

코살구 회원가입 문의

0

40

2

코살구 로그인 문제

0

60

2

3-A 문제 풀이 관련 질문

0

51

3

2-O 질문 있습니다

0

38

2

2-T 문제에 관한 질문

0

39

2

코딩 살구 클럽 접속 및 사용방법 문의

0

58

2

안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~

0

64

2

코딩살구클럽 로그인문제

0

74

3

코딩 살구 클럽 로그인 문제

0

79

2

2-J 채점관련 질문

0

65

3

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

0

77

1

살구클럽 아이디 없음 문제

0

76

1

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

0

60

2

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

0

57

1

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

1

74

2

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

0

66

2

1-H 문제 채점하기 오류

0

58

3

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

0

52

2