오일러 프로젝트 85

균일한 격자 내에서 만들 수 있는 직사각형의 개수에 관한 문제이다. 눈금의 크기가 1인 격자에서 가로, 세로를 정했을 때 그 속에서 만들 수 있는 직사각형의 개수가 2백만개에 가장 근접할 때의 가로/세로를 구하는 것이다.

격자의 가로 크기를 x, 세로 크기를 y라 했을 때 그 내부에 존재하는 직사각형들의 가로 크기는 1, 2, 3, … x 이고 세로 크기도 1, 2, 3, … y 가 된다. 가로가 a 일 때 이 폭으로 x 에 들어갈 수 이는 경우는 (x + 1 – a) 개 만큼 있다. 세로의 경우에도 세로가 b라면 (x + 1 – b)개의 경우가 있을 수 있다. 따라서 a*b의 크기인 사각형은 x, y 내에 (x + 1 – a)*(y + 1 – b)개가 있을 수 있다.

가로 세로가 각각 x, y 인 경우 내부에 들어가는 모든 직사각형의 개수는 x, y 이하의 작은 양의 정수 a, b에 대해서 다음의 식으로 표현할 수 있다.

\sum\limits_{a=1}^{x}{x-a+1} \times \sum\limits_{b=1}^{y}{y-b+1}

이 식을 풀면 \frac{1}{4}( (x^{2}+x) \times (y^{2}+y)) 가 된다.

이를 적용해서 x, y 가 ‘적절한’ 값일 때 200만과의 차이가 최소가 되는 범위를 찾는다. 이 값들은 x, y가 각각 커질 때 마다 증가하게 된다. 참고로 x, y 가 각각 100일 때 이 값은 2,500백만 정도 되므로 x, y가 1…100 범위에 있는 경우를 가정해서 계산해보면 답을 구할 수 있다.

def nrects(x, y):
    return (x * (x + 1) * y * (y + 1) // 4
def main():
    limit = 2 * 10**6
    ws = [(abs(nrects(x, y) -limit), x * y)
          for x in range(1, 101) for y in range(1, 101)]
    print(min(ws)[1])
main()

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