오일러 프로젝트 21

n의 약수들 중에서 자신을 제외한 것의 합을 d(n)으로 정의했을 때, 서로 다른 두 정수 a, b에 대하여 d(a) = b 이고 d(b) = a 이면 a, b는 친화쌍이라 하고 a와 b를 각각 친화수(우애수)라고 합니다. 예를 들어 220의 약수는 자신을 제외하면 1, 2, 4, 5, 10, 11, 20, 22, 44, 55, 110 이므로 그 합은 d(220) = 284 입니다. 또 284의 약수는 자신을 제외하면 1, 2, 4, 71, 142 이므로 d(284) = 220 입니다. 따라서 220과 284는 친화쌍이 됩니다. 10000 이하의 친화수들을 모두 찾아서 그 합을 구하세요.

http://euler.synap.co.kr/prob_detail.php?id=21

접근

친화쌍인 수들을 찾아서 그 합을 구하는 문제이다. 친화수는 서로가 서로의 진약수의 합인 수들로, 이를 찾기 위해서는 약수의 합을 빠르게 찾는 방법을 결정하는 것이 중요하다. 사실 최대 크기가 10,000 밖에 되지 않으므로 제곱근 이하의 수로 모두 나눠보는 것이 가장 편하고 빠른 방법이 될 것이다.

자연수 n에 대해서 진약수의 합을 m 이라 할 때, m이 1만 이하의 수이고, m의 진약수의 합이 n이라면 둘은 조건을 만족한다. 그리고 n에 대해서 친화쌍인 m을 찾았다면 m에 대해서는 이 과정을 굳이 반복할 필요가 없다. 따라서 이미 찾은 친화쌍들 중에 없는 수에 대해서만 확인하면 된다.

또 한가지 이 문제에서 실수하기 쉬운 것은 자기 자신을 제외한 약수의 합이 자신과 같은 수이다. 대표적으로는 1이 그러한데, 이런 수들이 제법 있기 때문에 오답을 내는 경우가 많다. 자기 자신과는 친화쌍을 이루지 않는다.

%%time

def s(n: int) -> int:
  s, l = 1, int(n ** .5)
  a = 2
  while a <= l:
    if n % a == 0:
      s += (a + n // a)
    a += 1
  if l * l == n:
    s -= l
  return s

res = set()
for n in range(2, 10001):
  if n not in res:
    m = s(n)
    if m <= 10000 and m != n and s(m) == n:
      res |= {m, n}
print(sum(res))

Read more

워드프레스에서 고스트로 이전

워드프레스에서 고스트로 이전

이 글을 쓰면서도 믿기 힘든 사실인데, 블로그라는 걸 처음 시작한지가 20년이 되었습니다. 이글루스에서 처음 시작했다가, SK컴즈가 인수한다고 발표함과 동시에 워드프레스로 플랫폼을 옮겼죠. 워드프레스오 옮긴 이후에는 호스팅 환경을 이리 저리 옮기긴 했지만 거의 18년 가까이 워드프레스를 사용해온 것 같습니다. 그 동안 워드프레스는 블로깅 툴에서 명실상부한 범용CMS로 발전했습니다. 사실 웬만한 홈페이지들은 이제

By sooop
띄어쓰기에 대한 생각

띄어쓰기에 대한 생각

업무 메일을 쓸 때 가장 많이 쓰는 말 중에 하나가 메일 말미에 ‘업무에 참고 부탁 드립니다.‘인데요, 어느 날부터 아웃룩에서 이 ‘부탁 드립니다’가 틀렸다고 맞춤법 지적을 하기 시작했습니다. 맞는 말은 ‘부탁드립니다’라고 붙여 쓰는 거라고. 사실 아래아한글 시절부터 이전의 MS워드까지, 워드프로세서들의 한국어 맞춤법 검사 실력은 거의 있으나 마나 한

By sooop

구글 포토에서 아이클라우드로 탈출한 후기

한 때 구글 포토가 백업 용량을 무제한으로 제공해 주겠다고해서, 구글 포토를 사용해서 사진을 백업해왔습니다. 물론 이 이야기의 결말은 저나 이 글을 읽고 있는 여러분이나 모두 알고 있습니다. 사실 AI에게 학습 시킬 이미지 데이터를 모으기 위한 것일 뿐이라거나 하는 이야기는 그 당시에도 있었습니다만, 에이 그래도 구글인데 용량은 넉넉하게 주겠지…하는 순진한

By sooop

Julia의 함수 사용팁

연산자의 함수적 표기 Julia의 연산자는 기본적으로 함수이며, 함수 호출 표기와 같은 방식으로 호출하는 것이 가능합니다. 또한 그 자체로 함수이기 때문에 filter(), map() 과 같이 함수를 인자로 받는 함수에도 연산자를 그대로 적용하는 것이 가능합니다. 특히 + 연산자는 sum() 함수와 같이 여러 인자를 받아 인자들의 합을 구할 수 있습니다. 2 + 3 # = 5 +(2,

By sooop