본문 바로가기
반응형

전체 글320

[Project Euler 38] 어떤 수에 (1, 2, ... )를 곱해서 이어붙여 얻을 수 있는 가장 큰 1 ~ 9 팬디지털 숫자 숫자 192에 1, 2, 3을 각각 곱합니다. 192 × 1 = 192 192 × 2 = 384 192 × 3 = 576 곱한 결과를 모두 이어보면 192384576 이고, 이것은 1 ~ 9 팬디지털(pandigital)인 숫자입니다. 이런 과정을 편의상 '곱해서 이어붙이기'라고 부르기로 합니다. 같은 식으로 9와 (1, 2, 3, 4, 5)를 곱해서 이어붙이면 918273645 라는 1 ~ 9 팬디지털 숫자를 얻습니다. 어떤 정수와 (1, 2, ... , n)을 곱해서 이어붙였을 때 얻을 수 있는 가장 큰 아홉자리의 1 ~ 9 팬디지털 숫자는 무엇입니까? (단 n > 1) 이 문제를 풀려고 미뤄뒀던 32번 팬디지털 문제를 풀었다. 예전에는 끙끙거리면서 결국 못 풀었는데 요즘 그래도 늘고 있는지 둘 다 .. 2016. 5. 4.
탐색 알고리즘 - 선형탐색, 이진탐색, 이진트리 탐색 1. 선형탐색(Linear Search Algorithm / Sequential Search Algorithm) - 리스트에서 특정한 값을 찾는 알고리즘의 하나. 리스트에서 찾고자 하는 값을 맨 앞에서부터 끝까지 차례대로 찾아 나간다. - 검색할 리스트의 길이가 길면 비효율적이지만, 검색방법 중 가장 단순하여 구현이 쉽고, 정렬되지 않은 리스트에서도 사용할 수 있다. - 예를 들어, 알파벳_list라는 리스트가 있다고 치자. 1알파벳_list = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j']cs 이렇게 10개의 알파벳 string을 가지고 있다. 이 경우 우리가 하나의 알파벳을 뽑아낸다고 할 때, 최고의 경우(best case)는, 'a'를 뽑아낼 때이다. 뽑.. 2016. 5. 3.
[Project Euler 32] 1~9 팬디지털 곱셈식을 만들 수 있는 모든 수의 합 1부터 n까지의 각 숫자를 한번씩만 써서 만들 수 있는 숫자를 팬디지털(pandigital)이라고 합니다. 예를 들면 15234는 1부터 5의 숫자가 한번씩만 쓰였으므로 1 ~ 5 팬디지털입니다. 7254라는 숫자는 그런 면에서 특이한데, 39 × 186 = 7254 라는 곱셈식을 만들 때 이것이 1 ~ 9 팬디지털이 되기 때문입니다. 이런 식으로 a × b = c 가 1 ~ 9 팬디지털이 되는 모든 c의 합은 얼마입니까? (참고: 어떤 c는 두 개 이상의 (a, b)쌍에 대응될 수도 있는데, 이런 경우는 하나로 칩니다) 오늘 건...좀 멍청하게 짰다. 수도코드도 짜지 않았고... 풀기 귀찮아서 계속 미루다가 38번이 팬디지털을 응용하는 문제여서 풀었다. 좀더 예쁘게 짤 수 있을 것 같은데... 팬디지털.. 2016. 5. 2.
마이클 스트라진스키 <어메이징 스파이더맨> 스파이더맨은 시리즈가 너무 많아서 뭐부터 시작해야 할지 모르겠다. 일단은 시공사에서 나온 어메이징 시리즈부터 시작. 평이 꽤 좋아서 사봤다. 작가는 마이클 스트라진스키. 그림작가는 시리즈를 그린 존 로미타 주니어다! 어쩐지 그림이 낯익더라. 내용으로 들어가자면... 일단 맨 첫 장에서 스파이더맨이 된 경위를 짧게 두 줄로(심지어 각주로) 설명해주고 바로 들어간다. 도시를 싸돌아다니다가 에제키엘이라는 할저씨를 만나는데, 본인과 능력이 굉장히 비슷함.(거미줄은 안 쐈다만...) 그리고 이런 할배는 항상 현자처럼 나오시지. (피터는 이 사람한테서 벤 삼촌을 느꼈다고 한다.) 띠, 띠용!!!!!!!!!! 에제키엘은 피터와는 좀 다른 방식으로 힘을 얻게 된 경우인데(피터처럼 순수한 방식은 아니었다고 함) 어쨌거나.. 2016. 5. 1.
반응형