euler-manager 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (499) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +21 -0
  3. data/Gemfile +4 -0
  4. data/LICENSE.txt +22 -0
  5. data/README.md +37 -0
  6. data/Rakefile +1 -0
  7. data/bin/euler +145 -0
  8. data/data/answers.yml +456 -0
  9. data/data/problems/1.yml +7 -0
  10. data/data/problems/10.yml +8 -0
  11. data/data/problems/100.yml +13 -0
  12. data/data/problems/101.yml +49 -0
  13. data/data/problems/102.yml +16 -0
  14. data/data/problems/103.yml +26 -0
  15. data/data/problems/104.yml +15 -0
  16. data/data/problems/105.yml +21 -0
  17. data/data/problems/106.yml +19 -0
  18. data/data/problems/107.yml +20 -0
  19. data/data/problems/108.yml +32 -0
  20. data/data/problems/109.yml +33 -0
  21. data/data/problems/11.yml +33 -0
  22. data/data/problems/110.yml +19 -0
  23. data/data/problems/111.yml +21 -0
  24. data/data/problems/112.yml +15 -0
  25. data/data/problems/113.yml +13 -0
  26. data/data/problems/114.yml +106 -0
  27. data/data/problems/115.yml +17 -0
  28. data/data/problems/116.yml +76 -0
  29. data/data/problems/117.yml +82 -0
  30. data/data/problems/118.yml +9 -0
  31. data/data/problems/119.yml +11 -0
  32. data/data/problems/12.yml +13 -0
  33. data/data/problems/120.yml +17 -0
  34. data/data/problems/121.yml +15 -0
  35. data/data/problems/122.yml +42 -0
  36. data/data/problems/123.yml +13 -0
  37. data/data/problems/124.yml +58 -0
  38. data/data/problems/125.yml +12 -0
  39. data/data/problems/126.yml +17 -0
  40. data/data/problems/127.yml +31 -0
  41. data/data/problems/128.yml +18 -0
  42. data/data/problems/129.yml +12 -0
  43. data/data/problems/13.yml +6 -0
  44. data/data/problems/130.yml +19 -0
  45. data/data/problems/131.yml +12 -0
  46. data/data/problems/132.yml +12 -0
  47. data/data/problems/133.yml +13 -0
  48. data/data/problems/134.yml +19 -0
  49. data/data/problems/135.yml +20 -0
  50. data/data/problems/136.yml +17 -0
  51. data/data/problems/137.yml +36 -0
  52. data/data/problems/138.yml +20 -0
  53. data/data/problems/139.yml +15 -0
  54. data/data/problems/14.yml +28 -0
  55. data/data/problems/140.yml +29 -0
  56. data/data/problems/141.yml +14 -0
  57. data/data/problems/142.yml +14 -0
  58. data/data/problems/143.yml +20 -0
  59. data/data/problems/144.yml +30 -0
  60. data/data/problems/145.yml +11 -0
  61. data/data/problems/146.yml +9 -0
  62. data/data/problems/147.yml +14 -0
  63. data/data/problems/148.yml +11 -0
  64. data/data/problems/149.yml +41 -0
  65. data/data/problems/15.yml +11 -0
  66. data/data/problems/150.yml +34 -0
  67. data/data/problems/151.yml +19 -0
  68. data/data/problems/152.yml +12 -0
  69. data/data/problems/153.yml +57 -0
  70. data/data/problems/154.yml +16 -0
  71. data/data/problems/155.yml +22 -0
  72. data/data/problems/156.yml +27 -0
  73. data/data/problems/157.yml +34 -0
  74. data/data/problems/158.yml +19 -0
  75. data/data/problems/159.yml +29 -0
  76. data/data/problems/16.yml +6 -0
  77. data/data/problems/160.yml +8 -0
  78. data/data/problems/161.yml +15 -0
  79. data/data/problems/162.yml +15 -0
  80. data/data/problems/163.yml +19 -0
  81. data/data/problems/164.yml +8 -0
  82. data/data/problems/165.yml +32 -0
  83. data/data/problems/166.yml +15 -0
  84. data/data/problems/167.yml +17 -0
  85. data/data/problems/168.yml +13 -0
  86. data/data/problems/169.yml +10 -0
  87. data/data/problems/17.yml +11 -0
  88. data/data/problems/170.yml +16 -0
  89. data/data/problems/171.yml +13 -0
  90. data/data/problems/172.yml +6 -0
  91. data/data/problems/173.yml +12 -0
  92. data/data/problems/174.yml +20 -0
  93. data/data/problems/175.yml +21 -0
  94. data/data/problems/176.yml +9 -0
  95. data/data/problems/177.yml +16 -0
  96. data/data/problems/178.yml +9 -0
  97. data/data/problems/179.yml +10 -0
  98. data/data/problems/18.yml +21 -0
  99. data/data/problems/180.yml +34 -0
  100. data/data/problems/181.yml +7 -0
  101. data/data/problems/182.yml +35 -0
  102. data/data/problems/183.yml +27 -0
  103. data/data/problems/184.yml +18 -0
  104. data/data/problems/185.yml +22 -0
  105. data/data/problems/186.yml +28 -0
  106. data/data/problems/187.yml +16 -0
  107. data/data/problems/188.yml +10 -0
  108. data/data/problems/189.yml +15 -0
  109. data/data/problems/19.yml +12 -0
  110. data/data/problems/190.yml +13 -0
  111. data/data/problems/191.yml +15 -0
  112. data/data/problems/192.yml +27 -0
  113. data/data/problems/193.yml +7 -0
  114. data/data/problems/194.yml +18 -0
  115. data/data/problems/195.yml +13 -0
  116. data/data/problems/196.yml +25 -0
  117. data/data/problems/197.yml +16 -0
  118. data/data/problems/198.yml +21 -0
  119. data/data/problems/199.yml +14 -0
  120. data/data/problems/2.yml +10 -0
  121. data/data/problems/20.yml +22 -0
  122. data/data/problems/200.yml +12 -0
  123. data/data/problems/201.yml +20 -0
  124. data/data/problems/202.yml +14 -0
  125. data/data/problems/203.yml +21 -0
  126. data/data/problems/204.yml +11 -0
  127. data/data/problems/205.yml +10 -0
  128. data/data/problems/206.yml +6 -0
  129. data/data/problems/207.yml +20 -0
  130. data/data/problems/208.yml +12 -0
  131. data/data/problems/209.yml +27 -0
  132. data/data/problems/21.yml +13 -0
  133. data/data/problems/210.yml +10 -0
  134. data/data/problems/211.yml +11 -0
  135. data/data/problems/212.yml +41 -0
  136. data/data/problems/213.yml +11 -0
  137. data/data/problems/214.yml +15 -0
  138. data/data/problems/215.yml +18 -0
  139. data/data/problems/216.yml +14 -0
  140. data/data/problems/217.yml +27 -0
  141. data/data/problems/218.yml +14 -0
  142. data/data/problems/219.yml +19 -0
  143. data/data/problems/22.yml +13 -0
  144. data/data/problems/220.yml +24 -0
  145. data/data/problems/221.yml +20 -0
  146. data/data/problems/222.yml +7 -0
  147. data/data/problems/223.yml +12 -0
  148. data/data/problems/224.yml +12 -0
  149. data/data/problems/225.yml +11 -0
  150. data/data/problems/226.yml +16 -0
  151. data/data/problems/227.yml +13 -0
  152. data/data/problems/228.yml +23 -0
  153. data/data/problems/229.yml +30 -0
  154. data/data/problems/23.yml +19 -0
  155. data/data/problems/230.yml +23 -0
  156. data/data/problems/231.yml +16 -0
  157. data/data/problems/232.yml +14 -0
  158. data/data/problems/233.yml +10 -0
  159. data/data/problems/234.yml +23 -0
  160. data/data/problems/235.yml +9 -0
  161. data/data/problems/236.yml +32 -0
  162. data/data/problems/237.yml +13 -0
  163. data/data/problems/238.yml +42 -0
  164. data/data/problems/239.yml +9 -0
  165. data/data/problems/24.yml +10 -0
  166. data/data/problems/240.yml +11 -0
  167. data/data/problems/241.yml +17 -0
  168. data/data/problems/242.yml +16 -0
  169. data/data/problems/243.yml +19 -0
  170. data/data/problems/244.yml +32 -0
  171. data/data/problems/245.yml +36 -0
  172. data/data/problems/246.yml +17 -0
  173. data/data/problems/247.yml +21 -0
  174. data/data/problems/248.yml +6 -0
  175. data/data/problems/249.yml +7 -0
  176. data/data/problems/25.yml +15 -0
  177. data/data/problems/250.yml +7 -0
  178. data/data/problems/251.yml +13 -0
  179. data/data/problems/252.yml +31 -0
  180. data/data/problems/253.yml +36 -0
  181. data/data/problems/254.yml +21 -0
  182. data/data/problems/255.yml +59 -0
  183. data/data/problems/256.yml +43 -0
  184. data/data/problems/257.yml +18 -0
  185. data/data/problems/258.yml +13 -0
  186. data/data/problems/259.yml +16 -0
  187. data/data/problems/26.yml +11 -0
  188. data/data/problems/260.yml +30 -0
  189. data/data/problems/261.yml +19 -0
  190. data/data/problems/262.yml +20 -0
  191. data/data/problems/263.yml +19 -0
  192. data/data/problems/264.yml +20 -0
  193. data/data/problems/265.yml +16 -0
  194. data/data/problems/266.yml +10 -0
  195. data/data/problems/267.yml +14 -0
  196. data/data/problems/268.yml +8 -0
  197. data/data/problems/269.yml +15 -0
  198. data/data/problems/27.yml +25 -0
  199. data/data/problems/270.yml +17 -0
  200. data/data/problems/271.yml +13 -0
  201. data/data/problems/272.yml +15 -0
  202. data/data/problems/273.yml +21 -0
  203. data/data/problems/274.yml +23 -0
  204. data/data/problems/275.yml +19 -0
  205. data/data/problems/276.yml +11 -0
  206. data/data/problems/277.yml +24 -0
  207. data/data/problems/278.yml +32 -0
  208. data/data/problems/279.yml +6 -0
  209. data/data/problems/28.yml +17 -0
  210. data/data/problems/280.yml +13 -0
  211. data/data/problems/281.yml +17 -0
  212. data/data/problems/282.yml +10 -0
  213. data/data/problems/283.yml +11 -0
  214. data/data/problems/284.yml +22 -0
  215. data/data/problems/285.yml +17 -0
  216. data/data/problems/286.yml +12 -0
  217. data/data/problems/287.yml +36 -0
  218. data/data/problems/288.yml +15 -0
  219. data/data/problems/289.yml +19 -0
  220. data/data/problems/29.yml +24 -0
  221. data/data/problems/290.yml +8 -0
  222. data/data/problems/291.yml +10 -0
  223. data/data/problems/292.yml +13 -0
  224. data/data/problems/293.yml +15 -0
  225. data/data/problems/294.yml +10 -0
  226. data/data/problems/295.yml +26 -0
  227. data/data/problems/296.yml +15 -0
  228. data/data/problems/297.yml +19 -0
  229. data/data/problems/298.yml +46 -0
  230. data/data/problems/299.yml +31 -0
  231. data/data/problems/3.yml +7 -0
  232. data/data/problems/30.yml +12 -0
  233. data/data/problems/300.yml +24 -0
  234. data/data/problems/301.yml +25 -0
  235. data/data/problems/302.yml +18 -0
  236. data/data/problems/303.yml +11 -0
  237. data/data/problems/304.yml +19 -0
  238. data/data/problems/305.yml +14 -0
  239. data/data/problems/306.yml +29 -0
  240. data/data/problems/307.yml +12 -0
  241. data/data/problems/308.yml +34 -0
  242. data/data/problems/309.yml +17 -0
  243. data/data/problems/31.yml +18 -0
  244. data/data/problems/310.yml +19 -0
  245. data/data/problems/311.yml +21 -0
  246. data/data/problems/312.yml +15 -0
  247. data/data/problems/313.yml +17 -0
  248. data/data/problems/314.yml +29 -0
  249. data/data/problems/315.yml +49 -0
  250. data/data/problems/316.yml +25 -0
  251. data/data/problems/317.yml +11 -0
  252. data/data/problems/318.yml +61 -0
  253. data/data/problems/319.yml +23 -0
  254. data/data/problems/32.yml +14 -0
  255. data/data/problems/320.yml +12 -0
  256. data/data/problems/321.yml +18 -0
  257. data/data/problems/322.yml +12 -0
  258. data/data/problems/323.yml +19 -0
  259. data/data/problems/324.yml +17 -0
  260. data/data/problems/325.yml +25 -0
  261. data/data/problems/326.yml +12 -0
  262. data/data/problems/327.yml +39 -0
  263. data/data/problems/328.yml +36 -0
  264. data/data/problems/329.yml +17 -0
  265. data/data/problems/33.yml +13 -0
  266. data/data/problems/330.yml +40 -0
  267. data/data/problems/331.yml +28 -0
  268. data/data/problems/332.yml +16 -0
  269. data/data/problems/333.yml +25 -0
  270. data/data/problems/334.yml +39 -0
  271. data/data/problems/335.yml +16 -0
  272. data/data/problems/336.yml +24 -0
  273. data/data/problems/337.yml +15 -0
  274. data/data/problems/338.yml +41 -0
  275. data/data/problems/339.yml +17 -0
  276. data/data/problems/34.yml +7 -0
  277. data/data/problems/340.yml +14 -0
  278. data/data/problems/341.yml +18 -0
  279. data/data/problems/342.yml +17 -0
  280. data/data/problems/343.yml +29 -0
  281. data/data/problems/344.yml +21 -0
  282. data/data/problems/345.yml +26 -0
  283. data/data/problems/346.yml +11 -0
  284. data/data/problems/347.yml +16 -0
  285. data/data/problems/348.yml +12 -0
  286. data/data/problems/349.yml +13 -0
  287. data/data/problems/35.yml +8 -0
  288. data/data/problems/350.yml +18 -0
  289. data/data/problems/351.yml +13 -0
  290. data/data/problems/352.yml +49 -0
  291. data/data/problems/353.yml +25 -0
  292. data/data/problems/354.yml +16 -0
  293. data/data/problems/355.yml +8 -0
  294. data/data/problems/356.yml +10 -0
  295. data/data/problems/357.yml +9 -0
  296. data/data/problems/358.yml +31 -0
  297. data/data/problems/359.yml +26 -0
  298. data/data/problems/36.yml +8 -0
  299. data/data/problems/360.yml +12 -0
  300. data/data/problems/361.yml +20 -0
  301. data/data/problems/362.yml +32 -0
  302. data/data/problems/363.yml +33 -0
  303. data/data/problems/364.yml +15 -0
  304. data/data/problems/365.yml +17 -0
  305. data/data/problems/366.yml +26 -0
  306. data/data/problems/367.yml +20 -0
  307. data/data/problems/368.yml +39 -0
  308. data/data/problems/369.yml +15 -0
  309. data/data/problems/37.yml +10 -0
  310. data/data/problems/370.yml +16 -0
  311. data/data/problems/371.yml +13 -0
  312. data/data/problems/372.yml +16 -0
  313. data/data/problems/373.yml +10 -0
  314. data/data/problems/374.yml +25 -0
  315. data/data/problems/375.yml +23 -0
  316. data/data/problems/376.yml +25 -0
  317. data/data/problems/377.yml +11 -0
  318. data/data/problems/378.yml +15 -0
  319. data/data/problems/379.yml +15 -0
  320. data/data/problems/38.yml +18 -0
  321. data/data/problems/380.yml +22 -0
  322. data/data/problems/381.yml +21 -0
  323. data/data/problems/382.yml +23 -0
  324. data/data/problems/383.yml +13 -0
  325. data/data/problems/384.yml +28 -0
  326. data/data/problems/385.yml +22 -0
  327. data/data/problems/386.yml +16 -0
  328. data/data/problems/387.yml +19 -0
  329. data/data/problems/388.yml +12 -0
  330. data/data/problems/389.yml +12 -0
  331. data/data/problems/39.yml +10 -0
  332. data/data/problems/390.yml +18 -0
  333. data/data/problems/391.yml +29 -0
  334. data/data/problems/392.yml +22 -0
  335. data/data/problems/393.yml +12 -0
  336. data/data/problems/394.yml +22 -0
  337. data/data/problems/395.yml +19 -0
  338. data/data/problems/396.yml +28 -0
  339. data/data/problems/397.yml +20 -0
  340. data/data/problems/398.yml +13 -0
  341. data/data/problems/399.yml +22 -0
  342. data/data/problems/4.yml +8 -0
  343. data/data/problems/40.yml +18 -0
  344. data/data/problems/400.yml +18 -0
  345. data/data/problems/401.yml +11 -0
  346. data/data/problems/402.yml +25 -0
  347. data/data/problems/403.yml +19 -0
  348. data/data/problems/404.yml +21 -0
  349. data/data/problems/405.yml +15 -0
  350. data/data/problems/406.yml +46 -0
  351. data/data/problems/407.yml +20 -0
  352. data/data/problems/408.yml +14 -0
  353. data/data/problems/409.yml +12 -0
  354. data/data/problems/41.yml +8 -0
  355. data/data/problems/410.yml +19 -0
  356. data/data/problems/411.yml +23 -0
  357. data/data/problems/412.yml +19 -0
  358. data/data/problems/413.yml +13 -0
  359. data/data/problems/414.yml +40 -0
  360. data/data/problems/415.yml +19 -0
  361. data/data/problems/416.yml +13 -0
  362. data/data/problems/417.yml +21 -0
  363. data/data/problems/418.yml +17 -0
  364. data/data/problems/419.yml +22 -0
  365. data/data/problems/42.yml +14 -0
  366. data/data/problems/420.yml +13 -0
  367. data/data/problems/421.yml +29 -0
  368. data/data/problems/422.yml +22 -0
  369. data/data/problems/423.yml +22 -0
  370. data/data/problems/424.yml +37 -0
  371. data/data/problems/425.yml +16 -0
  372. data/data/problems/426.yml +29 -0
  373. data/data/problems/427.yml +18 -0
  374. data/data/problems/428.yml +32 -0
  375. data/data/problems/429.yml +10 -0
  376. data/data/problems/43.yml +17 -0
  377. data/data/problems/430.yml +20 -0
  378. data/data/problems/431.yml +33 -0
  379. data/data/problems/432.yml +13 -0
  380. data/data/problems/433.yml +18 -0
  381. data/data/problems/434.yml +32 -0
  382. data/data/problems/435.yml +21 -0
  383. data/data/problems/436.yml +21 -0
  384. data/data/problems/437.yml +22 -0
  385. data/data/problems/438.yml +29 -0
  386. data/data/problems/439.yml +17 -0
  387. data/data/problems/44.yml +16 -0
  388. data/data/problems/440.yml +21 -0
  389. data/data/problems/441.yml +23 -0
  390. data/data/problems/442.yml +9 -0
  391. data/data/problems/443.yml +13 -0
  392. data/data/problems/444.yml +28 -0
  393. data/data/problems/445.yml +37 -0
  394. data/data/problems/446.yml +29 -0
  395. data/data/problems/447.yml +31 -0
  396. data/data/problems/448.yml +14 -0
  397. data/data/problems/449.yml +17 -0
  398. data/data/problems/45.yml +15 -0
  399. data/data/problems/450.yml +26 -0
  400. data/data/problems/451.yml +15 -0
  401. data/data/problems/452.yml +8 -0
  402. data/data/problems/453.yml +16 -0
  403. data/data/problems/454.yml +17 -0
  404. data/data/problems/455.yml +16 -0
  405. data/data/problems/456.yml +15 -0
  406. data/data/problems/46.yml +18 -0
  407. data/data/problems/47.yml +21 -0
  408. data/data/problems/48.yml +7 -0
  409. data/data/problems/49.yml +10 -0
  410. data/data/problems/5.yml +8 -0
  411. data/data/problems/50.yml +10 -0
  412. data/data/problems/51.yml +15 -0
  413. data/data/problems/52.yml +8 -0
  414. data/data/problems/53.yml +28 -0
  415. data/data/problems/54.yml +43 -0
  416. data/data/problems/55.yml +21 -0
  417. data/data/problems/56.yml +11 -0
  418. data/data/problems/57.yml +15 -0
  419. data/data/problems/58.yml +22 -0
  420. data/data/problems/59.yml +23 -0
  421. data/data/problems/6.yml +13 -0
  422. data/data/problems/60.yml +10 -0
  423. data/data/problems/61.yml +30 -0
  424. data/data/problems/62.yml +9 -0
  425. data/data/problems/63.yml +7 -0
  426. data/data/problems/64.yml +130 -0
  427. data/data/problems/65.yml +62 -0
  428. data/data/problems/66.yml +27 -0
  429. data/data/problems/67.yml +17 -0
  430. data/data/problems/68.yml +23 -0
  431. data/data/problems/69.yml +14 -0
  432. data/data/problems/7.yml +6 -0
  433. data/data/problems/70.yml +16 -0
  434. data/data/problems/71.yml +17 -0
  435. data/data/problems/72.yml +16 -0
  436. data/data/problems/73.yml +16 -0
  437. data/data/problems/74.yml +41 -0
  438. data/data/problems/75.yml +16 -0
  439. data/data/problems/76.yml +8 -0
  440. data/data/problems/77.yml +8 -0
  441. data/data/problems/78.yml +12 -0
  442. data/data/problems/79.yml +11 -0
  443. data/data/problems/8.yml +6 -0
  444. data/data/problems/80.yml +11 -0
  445. data/data/problems/81.yml +19 -0
  446. data/data/problems/82.yml +19 -0
  447. data/data/problems/83.yml +23 -0
  448. data/data/problems/84.yml +63 -0
  449. data/data/problems/85.yml +9 -0
  450. data/data/problems/86.yml +15 -0
  451. data/data/problems/87.yml +12 -0
  452. data/data/problems/88.yml +53 -0
  453. data/data/problems/89.yml +18 -0
  454. data/data/problems/9.yml +13 -0
  455. data/data/problems/90.yml +23 -0
  456. data/data/problems/91.yml +19 -0
  457. data/data/problems/92.yml +29 -0
  458. data/data/problems/93.yml +21 -0
  459. data/data/problems/94.yml +11 -0
  460. data/data/problems/95.yml +23 -0
  461. data/data/problems/96.yml +46 -0
  462. data/data/problems/97.yml +14 -0
  463. data/data/problems/98.yml +16 -0
  464. data/data/problems/99.yml +16 -0
  465. data/euler-manager.gemspec +31 -0
  466. data/euler-manager.sublime-project +12 -0
  467. data/example/1/README.md +6 -0
  468. data/example/1/ruby/1.rb +5 -0
  469. data/example/1/scala/1.scala +9 -0
  470. data/example/2/README.md +9 -0
  471. data/example/2/python/2.py +5 -0
  472. data/example/2/python/euler.py +0 -0
  473. data/example/Eulerfile.rb +87 -0
  474. data/example/README.md +26 -0
  475. data/example/lib/euler.py +0 -0
  476. data/example/lib/euler.rb +0 -0
  477. data/example/lib/euler.scala +5 -0
  478. data/lib/euler.rb +190 -0
  479. data/lib/euler/errors.rb +7 -0
  480. data/lib/euler/languages.rb +12 -0
  481. data/lib/euler/languages/coffeescript.rb +25 -0
  482. data/lib/euler/languages/javascript.rb +25 -0
  483. data/lib/euler/languages/python.rb +27 -0
  484. data/lib/euler/languages/ruby.rb +25 -0
  485. data/lib/euler/languages/scala.rb +27 -0
  486. data/lib/euler/languages/templates/coffeescript.coffee +5 -0
  487. data/lib/euler/languages/templates/javascript.js +5 -0
  488. data/lib/euler/languages/templates/python.py +5 -0
  489. data/lib/euler/languages/templates/ruby.rb +5 -0
  490. data/lib/euler/languages/templates/scala.scala +9 -0
  491. data/lib/euler/problem.rb +60 -0
  492. data/lib/euler/solution.rb +98 -0
  493. data/lib/euler/version.rb +3 -0
  494. data/scripts/update_problems +68 -0
  495. data/spec/euler/problem_spec.rb +5 -0
  496. data/spec/euler/solution_spec.rb +69 -0
  497. data/spec/euler_spec.rb +27 -0
  498. data/spec/spec_helper.rb +3 -0
  499. metadata +644 -0
@@ -0,0 +1,21 @@
1
+ ---
2
+ :id: 344
3
+ :name: Silver dollar game
4
+ :url: http://projecteuler.net/problem=344
5
+ :content: "\r\n<p>One variant of N.G. de Bruijn's <b>silver dollar</b> game can be
6
+ described as follows:</p>\r\n\r\n<p>On a strip of squares a number of coins are
7
+ placed, at most one coin per square. Only one coin, called the <b>silver dollar</b>,
8
+ has any value. Two players take turns making moves. At each turn a player must make
9
+ either a <i>regular</i> or a <i>special</i> move.</p>\r\n\r\n<p>A <i>regular</i>
10
+ move consists of selecting one coin and moving it one or more squares to the left.
11
+ The coin cannot move out of the strip or jump on or over another coin.</p>\r\n\r\n<p>Alternatively,
12
+ the player can choose to make the <i>special</i> move of pocketing the leftmost
13
+ coin rather than making a regular move. If no regular moves are possible, the player
14
+ is forced to pocket the leftmost coin.</p>\r\n\r\n<p>The winner is the player who
15
+ pockets the silver dollar.</p>\r\n\r\n\r\n<div align=\"center\">\r\n<img src=\"project/images/p_344_silverdollar.gif\"><br>\n</div>\r\n\r\n<p>A
16
+ <i>winning configuration</i> is an arrangement of coins on the strip where the first
17
+ player can force a win no matter what the second player does.</p>\r\n\r\n<p>Let
18
+ W(<var>n</var>,<var>c</var>) be the number of winning configurations for a strip
19
+ of <var>n</var> squares, <var>c</var> worthless coins and one silver dollar.</p>\r\n\r\n<p>You
20
+ are given that W(10,2) = 324 and W(100,10) = 1514704946113500.</p>\r\n\r\n<p>Find
21
+ W(1 000 000, 100) modulo the semiprime 1000 036 000 099 (= 1 000 003 · 1 000 033).\r\n</p>\r\n\r\n"
@@ -0,0 +1,26 @@
1
+ ---
2
+ :id: 345
3
+ :name: Matrix Sum
4
+ :url: http://projecteuler.net/problem=345
5
+ :content: "\r\n<p>We define the Matrix Sum of a matrix as the maximum sum of matrix
6
+ elements with each element being the only one in his row and column. For example,
7
+ the Matrix Sum of the matrix below equals 3315 ( = 863 + 383 + 343 + 959 + 767):</p>\r\n\r\n<p
8
+ style=\"text-align:center;font-family:courier new;\">\r\n  7  53 183 439 <span style=\"color:#00ff00;font-family:courier
9
+ new;\"><b>863</b></span><br>\r\n497 <span style=\"color:#00ff00;font-family:courier
10
+ new;\"><b>383</b></span> 563  79 973<br>\r\n287  63 <span style=\"color:#00ff00;font-family:courier
11
+ new;\"><b>343</b></span> 169 583<br>\r\n627 343 773 <span style=\"color:#00ff00;font-family:courier
12
+ new;\"><b>959</b></span> 943<br><span style=\"color:#00ff00;font-family:courier
13
+ new;\"><b>767</b></span> 473 103 699 303<br></p>\r\n\r\n<p>\r\nFind the Matrix Sum
14
+ of:<br></p>\r\n<p style=\"text-align:center;font-family:courier new;\">\r\n  7  53
15
+ 183 439 863 497 383 563  79 973 287  63 343 169 583<br>\r\n627 343 773 959 943 767
16
+ 473 103 699 303 957 703 583 639 913<br>\r\n447 283 463  29  23 487 463 993 119 883
17
+ 327 493 423 159 743<br>\r\n217 623   3 399 853 407 103 983  89 463 290 516 212 462
18
+ 350<br>\r\n960 376 682 962 300 780 486 502 912 800 250 346 172 812 350<br>\r\n870
19
+ 456 192 162 593 473 915  45 989 873 823 965 425 329 803<br>\r\n973 965 905 919 133
20
+ 673 665 235 509 613 673 815 165 992 326<br>\r\n322 148 972 962 286 255 941 541 265
21
+ 323 925 281 601  95 973<br>\r\n445 721  11 525 473  65 511 164 138 672  18 428 154
22
+ 448 848<br>\r\n414 456 310 312 798 104 566 520 302 248 694 976 430 392 198<br>\r\n184
23
+ 829 373 181 631 101 969 613 840 740 778 458 284 760 390<br>\r\n821 461 843 513  17
24
+ 901 711 993 293 157 274  94 192 156 574<br>\r\n 34 124   4 878 450 476 712 914 838
25
+ 669 875 299 823 329 699<br>\r\n815 559 813 459 522 788 168 586 966 232 308 833 251
26
+ 631 107<br>\r\n813 883 451 509 615  77 281 613 459 205 380 274 302  35 805<br></p>\r\n"
@@ -0,0 +1,11 @@
1
+ ---
2
+ :id: 346
3
+ :name: Strong Repunits
4
+ :url: http://projecteuler.net/problem=346
5
+ :content: "\r\n<p>\r\nThe number 7 is special, because 7 is 111 written in base 2,
6
+ and 11 written in base 6 <br>(i.e. 7<sub>10</sub> = 11<sub>6</sub> = 111<sub>2</sub>).
7
+ In other words, 7 is a repunit in at least two bases b &gt; 1. \r\n</p>\r\n<p>\r\nWe
8
+ shall call a positive integer with this property a strong repunit. It can be verified
9
+ that there are 8 strong repunits below 50: {1,7,13,15,21,31,40,43}. <br>Furthermore,
10
+ the sum of all strong repunits below 1000 equals 15864.\r\n</p>\r\nFind the sum
11
+ of all strong repunits below 10<sup>12</sup>.\r\n\r\n\r\n\r\n"
@@ -0,0 +1,16 @@
1
+ ---
2
+ :id: 347
3
+ :name: Largest integer divisible by two primes
4
+ :url: http://projecteuler.net/problem=347
5
+ :content: "\r\n<p>\r\nThe largest integer <img src=\"images/symbol_le.gif\" width=\"10\"
6
+ height=\"12\" alt=\"≤\" border=\"0\" style=\"vertical-align:middle;\"> 100 that
7
+ is only divisible by both the primes 2 and 3 is 96, as 96=32*3=2<sup>5</sup>*3.\r\nFor
8
+ two <i>distinct</i> primes p and q let M(p,q,N) be the largest positive integer
9
+ <img src=\"images/symbol_le.gif\" width=\"10\" height=\"12\" alt=\"≤\" border=\"0\"
10
+ style=\"vertical-align:middle;\">N only divisible\r\nby both p and q and M(p,q,N)=0
11
+ if such a positive integer does not exist.\r\n</p>\r\n<p>\r\nE.g. M(2,3,100)=96.<br>
12
+ \r\nM(3,5,100)=75 and not 90 because 90 is divisible by 2 ,3 and 5.<br>\r\nAlso
13
+ M(2,73,100)=0 because there does not exist a positive integer <img src=\"images/symbol_le.gif\"
14
+ width=\"10\" height=\"12\" alt=\"≤\" border=\"0\" style=\"vertical-align:middle;\">
15
+ 100 that is divisible by both 2 and 73.\r\n</p>\r\n<p>\r\nLet S(N) be the sum of
16
+ all distinct M(p,q,N).\r\nS(100)=2262.\r\n</p>\r\n<p>\r\nFind S(10 000 000).\r\n</p>\r\n\r\n\r\n\r\n\r\n\r\n"
@@ -0,0 +1,12 @@
1
+ ---
2
+ :id: 348
3
+ :name: Sum of a square and a cube
4
+ :url: http://projecteuler.net/problem=348
5
+ :content: "\r\n<p>Many numbers can be expressed as the sum of a square and a cube.
6
+ Some of them in more than one way.</p>\r\n\r\n<p>Consider the palindromic numbers
7
+ that can be expressed as the sum of a square and a cube, both greater than 1, in
8
+ <b>exactly</b> 4 different ways.<br>\r\nFor example, 5229225 is a palindromic number
9
+ and it can be expressed in exactly 4 different ways:</p>\r\n<p>2285<sup>2</sup>
10
+ + 20<sup>3</sup><br>\r\n2223<sup>2</sup> + 66<sup>3</sup><br>\r\n1810<sup>2</sup>
11
+ + 125<sup>3</sup><br>\r\n1197<sup>2</sup> + 156<sup>3</sup></p>\r\n \r\n<p>Find
12
+ the sum of the five smallest such palindromic numbers.</p>\r\n\r\n"
@@ -0,0 +1,13 @@
1
+ ---
2
+ :id: 349
3
+ :name: Langton's ant
4
+ :url: http://projecteuler.net/problem=349
5
+ :content: "\r\n<p>\r\nAn ant moves on a regular grid of squares that are coloured
6
+ either black or white.<br> \r\nThe ant is always oriented in one of the cardinal
7
+ directions (left, right, up or down) and moves from square to adjacent square according
8
+ to the following rules:<br>\r\n- if it is on a black square, it flips the color
9
+ of the square to white, rotates 90 degrees counterclockwise and moves forward one
10
+ square.<br>\r\n- if it is on a white square, it flips the color of the square to
11
+ black, rotates 90 degrees clockwise and moves forward one square.<br></p>\r\n<p>\r\nStarting
12
+ with a grid that is entirely white, how many squares are black after 10<sup>18</sup>
13
+ moves of the ant?\r\n</p>\r\n\r\n"
@@ -0,0 +1,8 @@
1
+ ---
2
+ :id: 35
3
+ :name: Circular primes
4
+ :url: http://projecteuler.net/problem=35
5
+ :content: "\r\n\n<p>The number, 197, is called a circular prime because all rotations
6
+ of the digits: 197, 971, and 719, are themselves prime.</p>\n<p>There are thirteen
7
+ such primes below 100: 2, 3, 5, 7, 11, 13, 17, 31, 37, 71, 73, 79, and 97.</p>\n<p>How
8
+ many circular primes are there below one million?</p>\n\r\n"
@@ -0,0 +1,18 @@
1
+ ---
2
+ :id: 350
3
+ :name: Constraining the least greatest and the greatest least
4
+ :url: http://projecteuler.net/problem=350
5
+ :content: "\r\n<p>A <i>list of size n</i> is a sequence of <var>n</var> natural numbers.<br>
6
+ Examples are (2,4,6), (2,6,4), (10,6,15,6), and (11).\r\n</p>\n<p>\r\nThe <b>greatest
7
+ common divisor</b>, or gcd, of a list is the largest natural number that divides
8
+ all entries of the list. <br>Examples: gcd(2,6,4) = 2, gcd(10,6,15,6) = 1 and gcd(11)
9
+ = 11.\r\n</p>\n<p>\r\nThe <b>least common multiple</b>, or lcm, of a list is the
10
+ smallest natural number divisible by each entry of the list. <br>Examples: lcm(2,6,4)
11
+ = 12, lcm(10,6,15,6) = 30 and lcm(11) = 11.\r\n</p>\n<p>\r\nLet f(<var>G</var>,
12
+ <var>L</var>, <var>N</var>) be the number of lists of size <var>N</var> with gcd
13
+ <img src=\"images/symbol_ge.gif\" width=\"10\" height=\"12\" alt=\"≥\" border=\"0\"
14
+ style=\"vertical-align:middle;\"><var>G</var> and lcm <img src=\"images/symbol_le.gif\"
15
+ width=\"10\" height=\"12\" alt=\"≤\" border=\"0\" style=\"vertical-align:middle;\"><var>L</var>.
16
+ For example:\r\n</p>\n<p>\r\nf(10, 100, 1) = 91.<br>\r\nf(10, 100, 2) = 327.<br>\r\nf(10,
17
+ 100, 3) = 1135.<br>\r\nf(10, 100, 1000) mod 101<sup>4</sup> = 3286053.\r\n</p>\n<p>\r\nFind
18
+ f(10<sup>6</sup>, 10<sup>12</sup>, 10<sup>18</sup>) mod 101<sup>4</sup>.\r\n</p>\r\n\r\n"
@@ -0,0 +1,13 @@
1
+ ---
2
+ :id: 351
3
+ :name: Hexagonal orchards
4
+ :url: http://projecteuler.net/problem=351
5
+ :content: "\r\n<p>A <i>hexagonal orchard</i> of order <var>n</var> is a triangular
6
+ lattice made up of points within a regular hexagon with side <var>n</var>. The following
7
+ is an example of a hexagonal orchard of order 5:\r\n</p>\r\n\r\n<div align=\"center\">\r\n<img
8
+ src=\"project/images/p_351_hexorchard.png\"><br>\n</div>\r\n\r\n<p>\r\nHighlighted
9
+ in green are the points which are hidden from the center by a point closer to it.
10
+ It can be seen that for a hexagonal orchard of order 5, 30 points are hidden from
11
+ the center.\r\n</p>\r\n\r\n<p>\r\nLet H(<var>n</var>) be the number of points hidden
12
+ from the center in a hexagonal orchard of order <var>n</var>.\r\n</p>\r\n\r\n<p>\r\nH(5)
13
+ = 30. H(10) = 138. H(1 000) = 1177848.\r\n</p>\r\n\r\n<p>\r\nFind H(100 000 000).\r\n</p>\r\n"
@@ -0,0 +1,49 @@
1
+ ---
2
+ :id: 352
3
+ :name: Blood tests
4
+ :url: http://projecteuler.net/problem=352
5
+ :content: "\r\n<p>\r\nEach one of the 25 sheep in a flock must be tested for a rare
6
+ virus, known to affect 2% of the sheep population.\r\nAn accurate and extremely
7
+ sensitive PCR test exists for blood samples, producing a clear positive / negative
8
+ result, but it is very time-consuming and expensive.\r\n</p>\r\n\r\n<p>\r\nBecause
9
+ of the high cost, the vet-in-charge suggests that instead of performing 25 separate
10
+ tests, the following procedure can be used instead:<br><br>\r\nThe sheep are split
11
+ into 5 groups of 5 sheep in each group. \r\nFor each group, the 5 samples are mixed
12
+ together and a single test is performed. Then,\r\n</p>\n<ul>\n<li>If the result
13
+ is negative, all the sheep in that group are deemed to be virus-free.</li>\r\n<li>If
14
+ the result is positive, 5 additional tests will be performed (a separate test for
15
+ each animal) to determine the affected individual(s).</li>\r\n</ul>\n<p>\r\nSince
16
+ the probability of infection for any specific animal is only 0.02, the first test
17
+ (on the pooled samples) for each group will be:\r\n</p>\n<ul>\n<li>Negative (and
18
+ no more tests needed) with probability 0.98<sup>5</sup> = 0.9039207968.</li>\r\n<li>Positive
19
+ (5 additional tests needed) with probability 1 - 0.9039207968 = 0.0960792032.</li>\r\n</ul>\n<p>\r\nThus,
20
+ the expected number of tests for each group is 1 + 0.0960792032 <img src=\"images/symbol_times.gif\"
21
+ width=\"9\" height=\"9\" alt=\"×\" border=\"0\" style=\"vertical-align:middle;\">
22
+ 5 = 1.480396016.<br>\r\nConsequently, all 5 groups can be screened using an average
23
+ of only 1.480396016 <img src=\"images/symbol_times.gif\" width=\"9\" height=\"9\"
24
+ alt=\"×\" border=\"0\" style=\"vertical-align:middle;\"> 5 = <b>7.40198008</b> tests,
25
+ which represents a huge saving of more than 70% !\r\n</p>\r\n\r\n<p>\r\nAlthough
26
+ the scheme we have just described seems to be very efficient, it can still be improved
27
+ considerably (always assuming that the test is sufficiently sensitive and that there
28
+ are no adverse effects caused by mixing different samples). E.g.:\r\n</p>\n<ul>\n<li>We
29
+ may start by running a test on a mixture of all the 25 samples. It can be verified
30
+ that in about 60.35% of the cases this test will be negative, thus no more tests
31
+ will be needed. Further testing will only be required for the remaining 39.65% of
32
+ the cases.</li>\r\n<li>If we know that at least one animal in a group of 5 is infected
33
+ and the first 4 individual tests come out negative, there is no need to run a test
34
+ on the fifth animal (we know that it must be infected).</li>\r\n<li>We can try a
35
+ different number of groups / different number of animals in each group, adjusting
36
+ those numbers at each level so that the total expected number of tests will be minimised.</li>\r\n</ul>\n<p>\r\nTo
37
+ simplify the very wide range of possibilities, there is one restriction we place
38
+ when devising the most cost-efficient testing scheme: whenever we start with a mixed
39
+ sample, all the sheep contributing to that sample must be fully screened (i.e. a
40
+ verdict of infected / virus-free must be reached for all of them) before we start
41
+ examining any other animals.\r\n</p>\r\nFor the current example, it turns out that
42
+ the most cost-efficient testing scheme (we'll call it the <i>optimal strategy</i>)
43
+ requires an average of just <b>4.155452</b> tests!\r\n\r\n\r\n<p>\r\nUsing the optimal
44
+ strategy, let T(<var>s</var>,<var>p</var>) represent the average number of tests
45
+ needed to screen a flock of <var>s</var> sheep for a virus having probability <var>p</var>
46
+ to be present in any individual.<br>\r\nThus, rounded to six decimal places, T(25,
47
+ 0.02) = 4.155452 and T(25, 0.10) = 12.702124.\r\n</p>\r\n\r\n<p>\r\nFind ΣT(10000,
48
+ p) for p=0.01, 0.02, 0.03, ... 0.50.<br>\r\nGive your answer rounded to six decimal
49
+ places.\r\n</p>\r\n\r\n"
@@ -0,0 +1,25 @@
1
+ ---
2
+ :id: 353
3
+ :name: Risky moon
4
+ :url: http://projecteuler.net/problem=353
5
+ :content: "\r\n<p>\r\nA moon could be described by the sphere C(<var>r</var>) with
6
+ centre (0,0,0) and radius <var>r</var>. \r\n</p>\r\n\r\n<p>\r\nThere are stations
7
+ on the moon at the points on the surface of C(<var>r</var>) with integer coordinates.
8
+ The station at (0,0,<var>r</var>) is called North Pole station, the station at (0,0,-<var>r</var>)
9
+ is called South Pole station.\r\n</p>\r\n\r\n<p>\r\nAll stations are connected with
10
+ each other via the shortest road on the great arc through the stations. A journey
11
+ between two stations is risky. If <var>d</var> is the length of the road between
12
+ two stations, (<var>d</var>/(π <var>r</var>))<sup>2</sup> is a measure for the risk
13
+ of the journey (let us call it the risk of the road). If the journey includes more
14
+ than two stations, the risk of the journey is the sum of risks of the used roads.\r\n</p>\r\n\r\n<p>\r\nA
15
+ direct journey from the North Pole station to the South Pole station has the length
16
+ π<var>r</var> and risk 1. The journey from the North Pole station to the South Pole
17
+ station via (0,<var>r</var>,0) has the same length, but a smaller risk: (½π<var>r</var>/(π<var>r</var>))<sup>2</sup>+(½π<var>r</var>/(π<var>r</var>))<sup>2</sup>=0.5.\r\n</p>\r\n\r\n<p>\r\nThe
18
+ minimal risk of a journey from the North Pole station to the South Pole station
19
+ on C(<var>r</var>) is M(<var>r</var>).\r\n</p>\r\n\r\n<p>\r\nYou are given that
20
+ M(7)=0.1784943998 rounded to 10 digits behind the decimal point. \r\n</p>\r\n\r\n<p>\r\nFind
21
+ <img src=\"images/symbol_sum.gif\" width=\"11\" height=\"14\" alt=\"∑\" border=\"0\"
22
+ style=\"vertical-align:middle;\">M(2<sup>n</sup>-1) for 1<img src=\"images/symbol_le.gif\"
23
+ width=\"10\" height=\"12\" alt=\"≤\" border=\"0\" style=\"vertical-align:middle;\">n<img
24
+ src=\"images/symbol_le.gif\" width=\"10\" height=\"12\" alt=\"≤\" border=\"0\" style=\"vertical-align:middle;\">15.\r\n</p>\r\n\r\n<p>\r\nGive
25
+ your answer rounded to 10 digits behind the decimal point in the form a.bcdefghijk.\r\n</p>\r\n\r\n\r\n"
@@ -0,0 +1,16 @@
1
+ ---
2
+ :id: 354
3
+ :name: 'Distances in a bee''s honeycomb '
4
+ :url: http://projecteuler.net/problem=354
5
+ :content: "\r\n<p>Consider a honey bee's honeycomb where each cell is a perfect regular
6
+ hexagon with side length 1.</p>\r\n\r\n<div align=\"center\">\r\n<img src=\"project/images/p_354_bee_honeycomb.png\">\n</div>\r\n\r\n\r\n<p>\r\nOne
7
+ particular cell is occupied by the queen bee.<br>\r\nFor a positive real number
8
+ <var>L</var>, let B(<var>L</var>) count the cells with distance <var>L</var> from
9
+ the queen bee cell (all distances are measured from centre to centre); you may assume
10
+ that the honeycomb is large enough to accommodate for any distance we wish to consider.
11
+ <br>\r\nFor example, B(<img src=\"images/symbol_radic.gif\" width=\"14\" height=\"16\"
12
+ alt=\"√\" border=\"0\" style=\"vertical-align:middle;\">3) = 6, B(<img src=\"images/symbol_radic.gif\"
13
+ width=\"14\" height=\"16\" alt=\"√\" border=\"0\" style=\"vertical-align:middle;\">21)
14
+ = 12 and B(111 111 111) = 54.</p>\r\n\r\n<p>Find the number of <var>L</var> <img
15
+ src=\"images/symbol_le.gif\" width=\"10\" height=\"12\" alt=\"≤\" border=\"0\" style=\"vertical-align:middle;\">
16
+ 5·10<sup>11</sup> such that B(<var>L</var>) = 450.</p>\r\n"
@@ -0,0 +1,8 @@
1
+ ---
2
+ :id: 355
3
+ :name: Maximal coprime subset
4
+ :url: http://projecteuler.net/problem=355
5
+ :content: "\r\n<p>\r\nDefine Co(<var>n</var>) to be the maximal possible sum of a
6
+ set of mutually co-prime elements from {1, 2, ..., <var>n</var>}.<br> For example
7
+ Co(10) is 30 and hits that maximum on the subset {1, 5, 7, 8, 9}.\r\n</p>\r\n\r\n<p>\r\nYou
8
+ are given that Co(30) = 193 and Co(100) = 1356. \r\n</p>\r\n\r\n<p>Find Co(200000).\r\n</p>\r\n\r\n"
@@ -0,0 +1,10 @@
1
+ ---
2
+ :id: 356
3
+ :name: Largest roots of cubic polynomials
4
+ :url: http://projecteuler.net/problem=356
5
+ :content: "\r\n<p>\r\nLet <var>a</var><sub><var>n</var></sub> be the largest real
6
+ root of a polynomial <var>g</var>(x) = x<sup>3</sup> - 2<sup><var>n</var></sup>·x<sup>2</sup>
7
+ + <var>n</var>.<br>\r\nFor example, <var>a</var><sub>2</sub> = 3.86619826...</p>\r\n\r\n<p>\r\nFind
8
+ the last eight digits of<img style=\"vertical-align:middle\" src=\"project/images/p_356_cubicpoly1.gif\">.</p>\r\n\r\n<p>\r\n<u><i>Note</i></u>:
9
+ <img style=\"vertical-align:middle\" src=\"project/images/p_356_cubicpoly2.gif\">
10
+ represents the floor function.</p>\r\n\r\n"
@@ -0,0 +1,9 @@
1
+ ---
2
+ :id: 357
3
+ :name: Prime generating integers
4
+ :url: http://projecteuler.net/problem=357
5
+ :content: "\r\n<p>\r\nConsider the divisors of 30: 1,2,3,5,6,10,15,30.<br>\r\nIt can
6
+ be seen that for every divisor <var>d</var> of 30, <var>d</var>+30/<var>d</var>
7
+ is prime.\r\n</p>\r\n<p>\r\nFind the sum of all positive integers <var>n</var> not
8
+ exceeding 100 000 000<br>such that\r\nfor every divisor <var>d</var> of <var>n</var>,
9
+ <var>d</var>+<var>n</var>/<var>d</var> is prime.\r\n</p>\r\n\r\n"
@@ -0,0 +1,31 @@
1
+ ---
2
+ :id: 358
3
+ :name: Cyclic numbers
4
+ :url: http://projecteuler.net/problem=358
5
+ :content: "\r\n<p>A <b>cyclic number</b> with <var>n</var> digits has a very interesting
6
+ property:<br>\r\nWhen it is multiplied by 1, 2, 3, 4, ... <var>n</var>, all the
7
+ products have exactly the same digits, in the same order, but rotated in a circular
8
+ fashion!\r\n</p>\r\n\r\n<p>\r\nThe smallest cyclic number is the 6-digit number
9
+ 142857 :<br>\r\n142857 <img src=\"images/symbol_times.gif\" width=\"9\" height=\"9\"
10
+ alt=\"×\" border=\"0\" style=\"vertical-align:middle;\"> 1 = 142857<br>\r\n142857
11
+ <img src=\"images/symbol_times.gif\" width=\"9\" height=\"9\" alt=\"×\" border=\"0\"
12
+ style=\"vertical-align:middle;\"> 2 = 285714<br>\r\n142857 <img src=\"images/symbol_times.gif\"
13
+ width=\"9\" height=\"9\" alt=\"×\" border=\"0\" style=\"vertical-align:middle;\">
14
+ 3 = 428571<br>\r\n142857 <img src=\"images/symbol_times.gif\" width=\"9\" height=\"9\"
15
+ alt=\"×\" border=\"0\" style=\"vertical-align:middle;\"> 4 = 571428<br>\r\n142857
16
+ <img src=\"images/symbol_times.gif\" width=\"9\" height=\"9\" alt=\"×\" border=\"0\"
17
+ style=\"vertical-align:middle;\"> 5 = 714285<br>\r\n142857 <img src=\"images/symbol_times.gif\"
18
+ width=\"9\" height=\"9\" alt=\"×\" border=\"0\" style=\"vertical-align:middle;\">
19
+ 6 = 857142 \r\n</p>\r\n\r\n<p>\r\nThe next cyclic number is 0588235294117647 with
20
+ 16 digits :<br>\r\n0588235294117647 <img src=\"images/symbol_times.gif\" width=\"9\"
21
+ height=\"9\" alt=\"×\" border=\"0\" style=\"vertical-align:middle;\"> 1 = 0588235294117647<br>\r\n0588235294117647
22
+ <img src=\"images/symbol_times.gif\" width=\"9\" height=\"9\" alt=\"×\" border=\"0\"
23
+ style=\"vertical-align:middle;\"> 2 = 1176470588235294<br>\r\n0588235294117647 <img
24
+ src=\"images/symbol_times.gif\" width=\"9\" height=\"9\" alt=\"×\" border=\"0\"
25
+ style=\"vertical-align:middle;\"> 3 = 1764705882352941<br>\r\n...<br>\r\n0588235294117647
26
+ <img src=\"images/symbol_times.gif\" width=\"9\" height=\"9\" alt=\"×\" border=\"0\"
27
+ style=\"vertical-align:middle;\"> 16 = 9411764705882352\r\n</p>\r\n\r\n<p>\r\nNote
28
+ that for cyclic numbers, leading zeros are important.\r\n</p>\r\n\r\n<p>\r\nThere
29
+ is only one cyclic number for which, the eleven leftmost digits are 00000000137
30
+ and the five rightmost digits are 56789 (i.e., it has the form 00000000137...56789
31
+ with an unknown number of digits in the middle). Find the sum of all its digits.\r\n</p>\r\n\r\n"
@@ -0,0 +1,26 @@
1
+ ---
2
+ :id: 359
3
+ :name: Hilbert's New Hotel
4
+ :url: http://projecteuler.net/problem=359
5
+ :content: "\r\n<p>\r\nAn infinite number of people (numbered 1, 2, 3, etc.) are lined
6
+ up to get a room at Hilbert's newest infinite hotel. The hotel contains an infinite
7
+ number of floors (numbered 1, 2, 3, etc.), and each floor contains an infinite number
8
+ of rooms (numbered 1, 2, 3, etc.). \r\n</p>\r\n\r\n<p>\r\nInitially the hotel is
9
+ empty. Hilbert declares a rule on how the <var>n</var><sup>th</sup> person is assigned
10
+ a room: person <var>n</var> gets the first vacant room in the lowest numbered floor
11
+ satisfying either of the following:\r\n</p>\n<ul>\n<li>the floor is empty</li>\r\n<li>the
12
+ floor is not empty, and if the latest person taking a room in that floor is person
13
+ <var>m</var>, then <var>m</var> + <var>n</var> is a perfect square</li>\r\n</ul>\n<p>\r\nPerson
14
+ 1 gets room 1 in floor 1 since floor 1 is empty.\r\n<br>Person 2 does not get room
15
+ 2 in floor 1 since 1 + 2 = 3 is not a perfect square.\r\n<br>Person 2 instead gets
16
+ room 1 in floor 2 since floor 2 is empty.\r\n<br>Person 3 gets room 2 in floor 1
17
+ since 1 + 3 = 4 is a perfect square.\r\n</p>\r\n\r\n<p>\r\nEventually, every person
18
+ in the line gets a room in the hotel.\r\n</p>\r\n\r\n<p>\r\nDefine P(<var>f</var>,
19
+ <var>r</var>) to be <var>n</var> if person <var>n</var> occupies room <var>r</var>
20
+ in floor <var>f</var>, and 0 if no person occupies the room. Here are a few examples:\r\n<br>P(1,
21
+ 1) = 1\r\n<br>P(1, 2) = 3\r\n<br>P(2, 1) = 2\r\n<br>P(10, 20) = 440\r\n<br>P(25,
22
+ 75) = 4863\r\n<br>P(99, 100) = 19454\r\n</p>\r\n\r\n<p>\r\nFind the sum of all P(<var>f</var>,
23
+ <var>r</var>) for all positive <var>f</var> and <var>r</var> such that <var>f</var>
24
+ <img src=\"images/symbol_times.gif\" width=\"9\" height=\"9\" alt=\"×\" border=\"0\"
25
+ style=\"vertical-align:middle;\"><var>r</var> = 71328803586048 and give the last
26
+ 8 digits as your answer.\r\n</p>\r\n"
@@ -0,0 +1,8 @@
1
+ ---
2
+ :id: 36
3
+ :name: Double-base palindromes
4
+ :url: http://projecteuler.net/problem=36
5
+ :content: "\r\n\n<p>The decimal number, 585 = 1001001001<sub>2</sub> (binary), is
6
+ palindromic in both bases.</p>\n<p>Find the sum of all numbers, less than one million,
7
+ which are palindromic in base 10 and base 2.</p>\n<p class=\"info\">(Please note
8
+ that the palindromic number, in either base, may not include leading zeros.)</p>\n\r\n"
@@ -0,0 +1,12 @@
1
+ ---
2
+ :id: 360
3
+ :name: Scary Sphere
4
+ :url: http://projecteuler.net/problem=360
5
+ :content: "\r\n<p>\r\nGiven two points (x<sub>1</sub>,y<sub>1</sub>,z<sub>1</sub>)
6
+ and (x<sub>2</sub>,y<sub>2</sub>,z<sub>2</sub>) in three dimensional space, the
7
+ <b>Manhattan distance</b> between those points is defined as <br> |x<sub>1</sub>-x<sub>2</sub>|+|y<sub>1</sub>-y<sub>2</sub>|+|z<sub>1</sub>-z<sub>2</sub>|.\r\n</p>\r\n<p>\r\nLet
8
+ C(<var>r</var>) be a sphere with radius <var>r</var> and center in the origin O(0,0,0).<br>\r\nLet
9
+ I(<var>r</var>) be the set of all points with integer coordinates on the surface
10
+ of C(<var>r</var>).<br>\r\nLet S(<var>r</var>) be the sum of the Manhattan distances
11
+ of all elements of I(<var>r</var>) to the origin O.\r\n</p>\r\n<p>\r\nE.g. S(45)=34518.\r\n</p>\r\n<p>\r\nFind
12
+ S(10<sup>10</sup>).\r\n</p>\r\n\r\n\r\n\r\n"
@@ -0,0 +1,20 @@
1
+ ---
2
+ :id: 361
3
+ :name: Subsequence of Thue-Morse sequence
4
+ :url: http://projecteuler.net/problem=361
5
+ :content: "\r\n<p>The <b>Thue-Morse sequence</b> {T<sub><var>n</var></sub>} is a binary
6
+ sequence satisfying:</p>\r\n<ul>\n<li>T<sub>0</sub> = 0</li>\r\n<li>T<sub>2<var>n</var></sub>
7
+ = T<sub><var>n</var></sub>\n</li>\r\n<li>T<sub>2<var>n</var>+1</sub> = 1 - T<sub><var>n</var></sub>\n</li>\r\n</ul>\n<p>\r\nThe
8
+ first several terms of {T<sub><var>n</var></sub>} are given as follows:<br>\r\n01101001<span
9
+ style=\"color:red;\">10010</span>1101001011001101001....\r\n</p>\r\n\r\n<p>\r\nWe
10
+ define {A<sub><var>n</var></sub>} as the sorted sequence of integers such that the
11
+ binary expression of each element appears as a subsequence in {T<sub><var>n</var></sub>}.<br>\r\nFor
12
+ example, the decimal number 18 is expressed as 10010 in binary. 10010 appears in
13
+ {T<sub><var>n</var></sub>} (T<sub>8</sub> to T<sub>12</sub>), so 18 is an element
14
+ of {A<sub><var>n</var></sub>}.<br>\r\nThe decimal number 14 is expressed as 1110
15
+ in binary. 1110 never appears in {T<sub><var>n</var></sub>}, so 14 is not an element
16
+ of {A<sub><var>n</var></sub>}.\r\n</p>\r\n\r\n<p>\r\nThe first several terms of
17
+ A<sub><var>n</var></sub> are given as follows:<br></p>\n<div align=\"center\">\r\n<table
18
+ cellspacing=\"1\" cellpadding=\"5\" border=\"0\" align=\"center\">\n<tr>\n<td align=\"left\"><var>n</var></td>\n<td>0</td>\n<td>1</td>\n<td>2</td>\n<td>3</td>\n<td>4</td>\n<td>5</td>\n<td>6</td>\n<td>7</td>\n<td>8</td>\n<td>9</td>\n<td>10</td>\n<td>11</td>\n<td>12</td>\n<td>…</td>\n</tr>\n<tr>\n<td>A<sub><var>n</var></sub>\n</td>\n<td>0</td>\n<td>1</td>\n<td>2</td>\n<td>3</td>\n<td>4</td>\n<td>5</td>\n<td>6</td>\n<td>9</td>\n<td>10</td>\n<td>11</td>\n<td>12</td>\n<td>13</td>\n<td>18</td>\n<td>…</td>\n</tr>\n</table>\n</div>\r\n\r\n\r\n<p>\r\nWe
19
+ can also verify that A<sub>100</sub> = 3251 and A<sub>1000</sub> = 80852364498.\r\n</p>\r\n\r\n<p>\r\nFind
20
+ the last 9 digits of <img style=\"vertical-align:middle\" src=\"project/images/p_361_Thue-Morse1.gif\">.\r\n</p>\r\n"
@@ -0,0 +1,32 @@
1
+ ---
2
+ :id: 362
3
+ :name: Squarefree factors
4
+ :url: http://projecteuler.net/problem=362
5
+ :content: "\r\n<p>\r\nConsider the number 54.<br>\r\n54 can be factored in 7 distinct
6
+ ways into one or more factors larger than 1:<br>\r\n54, 2<img src=\"images/symbol_times.gif\"
7
+ width=\"9\" height=\"9\" alt=\"×\" border=\"0\" style=\"vertical-align:middle;\">27,
8
+ 3<img src=\"images/symbol_times.gif\" width=\"9\" height=\"9\" alt=\"×\" border=\"0\"
9
+ style=\"vertical-align:middle;\">18, 6<img src=\"images/symbol_times.gif\" width=\"9\"
10
+ height=\"9\" alt=\"×\" border=\"0\" style=\"vertical-align:middle;\">9, 3<img src=\"images/symbol_times.gif\"
11
+ width=\"9\" height=\"9\" alt=\"×\" border=\"0\" style=\"vertical-align:middle;\">3<img
12
+ src=\"images/symbol_times.gif\" width=\"9\" height=\"9\" alt=\"×\" border=\"0\"
13
+ style=\"vertical-align:middle;\">6, 2<img src=\"images/symbol_times.gif\" width=\"9\"
14
+ height=\"9\" alt=\"×\" border=\"0\" style=\"vertical-align:middle;\">3<img src=\"images/symbol_times.gif\"
15
+ width=\"9\" height=\"9\" alt=\"×\" border=\"0\" style=\"vertical-align:middle;\">9
16
+ and 2<img src=\"images/symbol_times.gif\" width=\"9\" height=\"9\" alt=\"×\" border=\"0\"
17
+ style=\"vertical-align:middle;\">3<img src=\"images/symbol_times.gif\" width=\"9\"
18
+ height=\"9\" alt=\"×\" border=\"0\" style=\"vertical-align:middle;\">3<img src=\"images/symbol_times.gif\"
19
+ width=\"9\" height=\"9\" alt=\"×\" border=\"0\" style=\"vertical-align:middle;\">3.<br>\r\nIf
20
+ we require that the factors are all squarefree only two ways remain: 3<img src=\"images/symbol_times.gif\"
21
+ width=\"9\" height=\"9\" alt=\"×\" border=\"0\" style=\"vertical-align:middle;\">3<img
22
+ src=\"images/symbol_times.gif\" width=\"9\" height=\"9\" alt=\"×\" border=\"0\"
23
+ style=\"vertical-align:middle;\">6 and 2<img src=\"images/symbol_times.gif\" width=\"9\"
24
+ height=\"9\" alt=\"×\" border=\"0\" style=\"vertical-align:middle;\">3<img src=\"images/symbol_times.gif\"
25
+ width=\"9\" height=\"9\" alt=\"×\" border=\"0\" style=\"vertical-align:middle;\">3<img
26
+ src=\"images/symbol_times.gif\" width=\"9\" height=\"9\" alt=\"×\" border=\"0\"
27
+ style=\"vertical-align:middle;\">3.\r\n</p>\r\n<p>\r\nLet's call Fsf(<var>n</var>)
28
+ the number of ways <var>n</var> can be factored into one or more squarefree factors
29
+ larger than 1, so\r\nFsf(54)=2.\r\n</p>\r\n<p>\r\nLet S(<var>n</var>) be <img src=\"images/symbol_sum.gif\"
30
+ width=\"11\" height=\"14\" alt=\"∑\" border=\"0\" style=\"vertical-align:middle;\">Fsf(<var>k</var>)
31
+ for <var>k</var>=2 to <var>n</var>.\r\n</p>\r\n<p>\r\nS(100)=193.\r\n</p>\r\n<p>\r\nFind
32
+ S(10 000 000 000). \r\n</p>\r\n\r\n\r\n"
@@ -0,0 +1,33 @@
1
+ ---
2
+ :id: 363
3
+ :name: Bézier Curves
4
+ :url: http://projecteuler.net/problem=363
5
+ :content: "\r\nA cubic Bézier curve is defined by four points: P<sub>0</sub>, P<sub>1</sub>,
6
+ P<sub>2</sub> and P<sub>3</sub>.\r\n<p>\r\n\r\nThe curve is constructed as follows:<br>\r\nOn
7
+ the segments P<sub>0</sub>P<sub>1</sub>, P<sub>1</sub>P<sub>2</sub> and P<sub>2</sub>P<sub>3</sub>
8
+ the points Q<sub>0</sub>,Q<sub>1</sub> and Q<sub>2</sub> are drawn such that P<sub>0</sub>Q<sub>0</sub>/P<sub>0</sub>P<sub>1</sub>=P<sub>1</sub>Q<sub>1</sub>/P<sub>1</sub>P<sub>2</sub>=P<sub>2</sub>Q<sub>2</sub>/P<sub>2</sub>P<sub>3</sub>=t
9
+ (t in [0,1]).<br>\r\nOn the segments Q<sub>0</sub>Q<sub>1</sub> and Q<sub>1</sub>Q<sub>2</sub>
10
+ the points R<sub>0</sub> and R<sub>1</sub> are drawn such that\r\nQ<sub>0</sub>R<sub>0</sub>/Q<sub>0</sub>Q<sub>1</sub>=Q<sub>1</sub>R<sub>1</sub>/Q<sub>1</sub>Q<sub>2</sub>=t
11
+ for the same value of t.<br>\r\nOn the segment R<sub>0</sub>R<sub>1</sub> the point
12
+ B is drawn such that R<sub>0</sub>B/R<sub>0</sub>R<sub>1</sub>=t for the same value
13
+ of t.\r\nThe Bézier curve defined by the points P<sub>0</sub>, P<sub>1</sub>, P<sub>2</sub>,
14
+ P<sub>3</sub> is the locus of B as Q<sub>0</sub> takes all possible positions on
15
+ the segment P<sub>0</sub>P<sub>1</sub>. (Please note that for all points the value
16
+ of t is the same.) \r\n<br></p>\r\n<p><applet code=\"CabriJava.class\" width=\"390\"
17
+ height=\"300\" align=\"right\" hspace=\"20\" archive=\"http://projecteuler.net/project/images/bezier/CabriJava.jar\">\r\n
18
+ \ <param name=\"lang\" value=\"en\">\n<param name=\"file\" value=\"http://projecteuler.net/project/images/bezier/bezier.fig\">\n<param
19
+ name=\"loop\" value=\"true\"></applet>\r\n</p>\r\n\r\n<p>\r\nIn the applet to the
20
+ right you can drag the points P<sub>0</sub>, P<sub>1</sub>, P<sub>2</sub> and P<sub>3</sub>
21
+ to see what the Bézier curve (green curve) defined by those points looks like.
22
+ You can also drag the point Q<sub>0</sub> along the segment P<sub>0</sub>P<sub>1</sub>.\r\n</p>\r\n<p>\r\nFrom
23
+ the construction it is clear that the Bézier curve will be tangent to the segments
24
+ P<sub>0</sub>P<sub>1</sub> in P<sub>0</sub> and P<sub>2</sub>P<sub>3</sub> in P<sub>3</sub>.\r\n</p>\r\n<p>\r\n<br><br><br></p>\r\n<p>\r\nA
25
+ cubic Bézier curve with P<sub>0</sub>=(1,0), P<sub>1</sub>=(1,<var>v</var>), P<sub>2</sub>=(<var>v</var>,1)
26
+ and P<sub>3</sub>=(0,1) is used to approximate a quarter circle.<br>\r\nThe value
27
+ <var>v</var><img src=\"images/symbol_gt.gif\" width=\"10\" height=\"10\" alt=\"&gt;\"
28
+ border=\"0\" style=\"vertical-align:middle;\">0 is chosen such that the area enclosed
29
+ by the lines OP<sub>0</sub>, OP<sub>3</sub> and the curve is equal to <sup>π</sup>/<sub>4</sub>
30
+ (the area of the quarter circle).\r\n</p>\r\n<p>\r\nBy how many percent does the
31
+ length of the curve differ from the length of the quarter circle?<br>\r\nThat is,
32
+ if L is the length of the curve, calculate 100*<sup>(L-π/2)</sup>/<sub>(π/2)</sub>.<br>\r\nGive
33
+ your answer rounded to 10 digits behind the decimal point.\r\n\r\n\r\n\r\n</p>"