오일러 프로젝트 34

수 145는 신기한 성질이 있습니다. 각 자릿수의 팩토리얼(계승)을 더하면 1! + 4! + 5! = 1 + 24 + 120 = 145 처럼 자기 자신이 됩니다. 이렇게 각 자릿수의 팩토리얼을 더하면 자기 자신이 되는 모든 수의 합을 구하세요.

단, 1! = 1, 2! = 2 의 경우는 덧셈이 아니므로 제외합니다.

https://euler.synap.co.kr/problem=34

9! = 362,880이며, 모든 자리가 9로 구성된 수들의 팩토리얼의 합은 이 값의 배수가 된다. 이 값의 배수는 4자리부터 9자리까지 모두 7자리 수의 값이 되므로, 7자리를 넘어가는 수는 각 자릿수의 팩토리얼 합이 자신이 될 수 없게 된다. 7자리 수에서도 2540160이 최대값이므로, 검사해야 하는 한계값이 이 값이 될 것이다.

팩토리얼을 계산해야 하는 수는 고작 10개 밖에 없으니 매번 계산하기 보다 계산해놓은 결과를 튜플에 기록해놓고 계산하면 수행 시간을 단축하는데 도움이 될 것이다.

fs = (1, 1, 2, 6, 24, 120, 720, 5040, 40320, 362880)

def test(n):
    ns = sum(fs[i] for i in map(int, str(n)))
    return ns == n

res = sum(filter(test, range(10, 362880 * 7)))
print(res)

250만 번 가량의 루프를 돌아야하지만, filter()를 사용하면 그나마 파이썬 루프의 오버헤드가 많이 줄어들기 때문에 몇 초 수준에서 답을 낼 수 있습니다.

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