오일러 프로젝트 77

77번문제는 앞선 문제인 76번이나 31번과 완전 같은 문제라 할 수 있다.  다만 동전의 액면가가 N 보다 작은 소수들이면 된다.

문제

숫자 10을 소수의 합으로 나타내는 방법은 모두 다섯 가지가 있습니다.

7 + 3
5 + 5
5 + 3 + 2
3 + 3 + 2 + 2
2 + 2 + 2 + 2 + 2

소수의 합으로 나타내는 방법이 5000가지가 넘는 최초의 숫자는 얼마입니까?

접근

N 값을 2부터 시작해서 1씩 증가하면서 N보다 작은 소수를 구하고, 이 집합을 동전의 집합으로 삼아 N을 만드는 경우의 수를 센다. 이 때 반복적으로 N 보자 작은 소수의 집합을 구하는 작업을 수행하기 때문에, 이 작업을 빠르게 처리하는 것이 전체 퍼포먼스를 향상시키는 길이다.

한계값이 정해진 범위에서 소수의 집합을 가장 빠르게 구할 수 있는 방법은 에라토스테네스의 체를 사용하는 것이고, 오일러 프로젝트를 풀면서 아래의 코드를 유용하게 사용했었다.

def sieve(n):
  s = [0, 0] + [1] * (n - 1)
  for i in range(2, n):
    if s[i] is 1:
      s[i*2::i] = [0] * ((n - i) // i)
  return [i for i, j in enumerate(s) if j > 0]

계산하기

N에 대해서 N보다 작은 소수의 합으로 N을 나타내는 방법은 다음과 같이 계산한다. 이는 31번, 영국 화폐의 조합과 같은 방식으로 풀어낸다.

def calc(n):
  ways = [1] + [0] * n
  for v in sieve(n):
    for i in range(v, n+1):
      ways[i] += ways[i - v]
  return ways[n]

이제 위 함수를 계속호출하면서 값이 5000이상되는 경우를 찾는다.

def e077():
  m = 2
  while calc(m) <= 5000:
    m += 1
  print(m)

https://repl.it/@sooop/EulerProject-077

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