알고리즘

BOJ :: [5624] 좋은 수

이쓴 2021. 9. 4. 13:34

문제

https://www.acmicpc.net/problem/5624

 

5624번: 좋은 수

정수 N개로 이루어진 수열 A가 있다. 이때, i번째 수가 그 앞에 있는 수 세 개의 합으로 나타낼 수 있을 때, 그 수를 좋다고 한다. (같은 위치에 있는 수를 여러 번 더해도 된다) 수열이 주어졌을 때

www.acmicpc.net

 

문제 요약

좋은 수 문제는 주어진 숫자들 중에서 i번째 수 보다 앞에 있는 수 3개를 더해 i번째 수를 만들 수 있다면 i번째 수를 좋은 수라고 한다. 즉, a + b + c = d를 만족하는 d가 몇 개인지를 구하는 문제이다. d보다 앞에 있는 수 중 3개를 뽑는 조합을 모두 구하려면 O(N^3)으로 주어진 문제의 N의 개수가 5000으로 시간 초과가 발생한다. 따라서 수식을 a + b = d - c로 변형시켜 a + b값을 저정해 놓고 d - c값이 존재하는지만 판별은 방법으로 시간 복잡도 O(N^2)으로 문제를 해결할 수 있다.

 

풀이

두 수를 더해서 나오는 수의 중복을 없애기 위해 set을 이용하여 수를 저장하고 d - c가 set에 존재하는지를 확인하는 방법으로 구현했다.

 

코드

import sys
input = sys.stdin.readline

n = int(input())
s = set()

arr = list(map(int, input().split()))

result = 0
s.add(arr[0] + arr[0])

for i in range(1, n):
    for j in range(i):
        if arr[i] - arr[j] in s:
            result += 1
            break
    
    for j in range(i+1):
        s.add(arr[i] + arr[j])

print(result)

 


작성한 글에 잘못된 부분이나 문제가 있는 경우 댓글에 작성해 주시면 수정하도록 하겠습니다 . 질문도 환영합니다! :)