오일러 프로젝트 63

n자리 수이면서 n제곱도 되는 양의 정수는 모두 몇 개?

다섯 자리 수인 16807은 75으로 5제곱수입니다. 또, 아홉자리 수인 134217728은 89으로 9제곱수입니다.

n자리 수이면서 n 제곱수도 되는 양의 정수는 모두 몇 개나 있습니까?

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

접근

자리 수는 상용로그를 통해서 구할 수 있다. 상용로그값의 정수부에 1을 더하면 원래의 수가 몇 자리로 되어 있는지 알 수 있다. 그렇다면 m의 n제곱이 어떤 수 A 일 때, A가 n 자리의 숫자라면, 이 관계식의 양변에 로그를 적용하여 아래와 같은 식으로 전개하여 n의 최대 범위를 구할 수 있다.

이 범위만 유도해낸다면 아주 쉽게 풀리는 문제이다.

참고로 m은 10보다 작은 자연수여야 한다. (두 자리 수를 제곱해서 두 자리 자연수가 될 수 없으므로…)

\begin{array}{llll}
\log_{10}m^n &=& n - 1 + k & ( 0 \le k \lt 1) \\
n \cdot \log_{10}{m} &\le& n - 1 \\
n(\log_{10}{m} - 1) &\le& - 1 \\
n &\le& 1 \div (1 - \log_{10}{m} )
\end{array}

m의 n제곱이 n자리가 될 수 있는 n의 최대 값은 (1 – (1 / log(m)) 으로 판정된다. 이 점을 이용해서 2 ~ 9 범위의 각 a에 대해서 최대 b 범위를 루프를 돌 수 있다. 전체 루프 수는 몇 번 되지 않기 때문에 답은 쉽게 구해진다.

from math import log10

s = set()
for a in range(2, 10):
  upper = int(1 / (1 - log10(a))) + 1
  for b in range(upper):
    s.add(a**b)
print(len(s))

# 48

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