2015年8月23日日曜日

150823(4)

Ruby


どの2つの和も立方数(7)

どの2つの和も立方数となるような異なる4個の自然数の組
のうちその和が小さなものから順に4つ並べると、
(1493580092, 2510949380, 7071213244, 51114333631)
(11948640736, 20087595040, 56569705952, 408914669048)
(40326662484, 67795633260, 190922757588, 1380087008037)
(95589125888, 160700760320, 452557647616, 3271317352384)
となる。
このことを以下のコードで確かめた。

# OEIS A018787(https://oeis.org/A018787/b018787.txt)のデータ
str =
'1 87539319
2 119824488
3 143604279
4 175959000
5 327763000
6 700314552
7 804360375
8 958595904
9 1148834232
10 1407672000
11 1840667192
12 1915865217
13 2363561613
14 2622104000
15 3080802816
16 3235261176
17 3499524728
18 3623721192
19 3877315533
20 4750893000
21 5544709352
22 5602516416
23 6434883000
24 7668767232
25 8849601000
26 9190673856
27 10458523413
28 10499580728
29 10833628897
30 10942414875
31 11261376000
32 14725337536
33 14978061000
34 15170835645
35 15326921736
36 17950534875
37 18778674824
38 18908492904
39 20976832000
40 21303180171
41 21717730125
42 21989186856
43 21994875000
44 24646422528
45 25882089408
46 26059452841
47 27996197824
48 28989769536
49 30025986417
50 31018524264
51 38007144000
52 38786216625
53 38947913424
54 40970375000
55 41099799384
56 44357674816
57 44820131328
58 49256267697
59 49698014184
60 51479064000
61 51728360859
62 53072642168
63 56065076613
64 60353937000
65 61350137856
66 62190076347
67 63816163551
68 70796808000
69 73525390848
70 83181676032
71 83668187304
72 83996645824
73 86669031176
74 87352051752
75 87539319000
76 90091008000
77 94487167656
78 97840472184
79 100545046875
80 104622178752
81 104687519391
82 106872501519
83 109568696139
84 112422709000
85 116514833589
86 117802700288
87 119068866189
88 119824488000
89 121366685160
90 122026235968
91 122615373888
92 128274111000
93 132651091125
94 142220774241
95 143604279000
96 149498759592
97 149707152504
98 150229398592
99 151267943232
100 159486393528
101 160780814649
102 167814656000
103 170425441368
104 173741841000
105 175913494848
106 175959000000
107 177853640328
108 184877417088
109 189855538327
110 191137295349
111 191450482496
112 192323883843
113 197171380224
114 207056715264
115 208438080643
116 208475622728
117 210662877789
118 223969582592
119 230083399000
120 231918156288
121 234201429000
122 235645700472
123 237565962991
124 238939227000
125 239226670592
126 239483152125
127 240207891336
128 243349354053
129 247620672000
130 248148194112
131 257906381824
132 263254400136
133 266927432616
134 275895608625
135 282380132151
136 283488679656
137 292507980219
138 295445201625
139 300634478586
140 304057152000
141 310289733000
142 311583307392
143 315498600963
144 319616506125
145 320465258659
146 327763000000
147 328798395072
148 330175414296
149 354861398528
150 358561050624
151 360113256776
152 381240326376
153 385100352000
154 386581923000
155 394050141576
156 397584113472
157 404407647000
158 409612562415
159 411832512000
160 413826886872
161 424581137344
162 430080674247
163 436252553000
164 437440591000
165 439386172407
166 448520612904
167 452965149000
168 472233009528
169 474894161469
170 482831496000
171 484664441625
172 490801102848
173 497520610776
174 499501199799
175 501172171344
176 507024220248
177 508252843000
178 509082282072
179 510529308408
180 513359176113
181 566374464000
182 575185864617
183 586378713375
184 588203126784
185 588697709544
186 593708045112
187 593861625000
188 600432189021
189 605275992496
190 620504707032
191 631348846856
192 646317255320
193 657141769431
194 665453408256
195 669345498432
196 671973166592
197 678755646296
198 680558704488
199 693088669000
200 693352249408
201 698816414016
202 700314552000
203 703605226707
204 705527822727
205 711087080067
206 720095311000
207 720728064000
208 736115010624
209 753431128632
210 755897341248
211 782638019072
212 782723777472
213 804360375000
214 806313656512
215 806895808056
216 810701633259
217 821876163192
218 836977430016
219 837500155128
220 854980012152
221 857052870219
222 864486567000
223 870434038656
224 872354677824
225 876549569112
226 899381672000
227 917600156649
228 932118668712
229 942421602304
230 950859559000
231 952550929512
232 958595904000
233 970933481280
234 976209887744
235 980922991104
236 984981749661
237 1001497375125
238 1001999997999
239 1006106826816
240 1014843272625
241 1019886765625
242 1022342420808
243 1026192888000
244 1047227848875
245 1051593662448
246 1056715365888
247 1061208729000
248 1065090894273
249 1070603659125
250 1097813860416
251 1103104702089
252 1106200125000
253 1109041710651
254 1109694583368
255 1125524213576
256 1137766193928
257 1147757021073
258 1148834232000
259 1154630906091
260 1178143119153
261 1195990076736
262 1197657220032
263 1200336981704
264 1201835188736
265 1206902781000
266 1210143545856
267 1242936368856
268 1275891148224
269 1286246517192
270 1295447561837
271 1307315426625
272 1312447591000
273 1329919227819
274 1341846382968
275 1342517248000
276 1350293881608
277 1354203612125
278 1363403530944
279 1367801859375
280 1376755179336
281 1389934728000
282 1396665743193
283 1399056055488
284 1407307958784
285 1407672000000
286 1422829122624
287 1432961338536
288 1457904545496
289 1479019336704
290 1513010536128
291 1513757068551
292 1518844306616
293 1521668864989
294 1529098362792
295 1531603859968
296 1538591070744
297 1568057335208
298 1577371041792
299 1580060482875
300 1610299619000
301 1629556299000
302 1651966490375
303 1656453722112
304 1658465000647
305 1659967644160
306 1667504645144
307 1667804981824
308 1679132061369
309 1685303022312
310 1723036415877
311 1747233262593
312 1767179743875
313 1791756660736
314 1840667192000
315 1842680339136
316 1855345250304
317 1872257625000
318 1873611432000
319 1885165603776
320 1896354455625
321 1900527703928
322 1901835307736
323 1911513816000
324 1913813364736
325 1915865217000
326 1921663130688
327 1946794832424
328 1980965376000
329 1985185552896
330 2063251054592
331 2106035201088
332 2112174838440
333 2134996451091
334 2135419460928
335 2140786353069
336 2140893153000
337 2175815002816
338 2207164869000
339 2210606903232
340 2235096962000
341 2243816859375
342 2245905252864
343 2248126417000
344 2259041057208
345 2267909437248
346 2307582801125
347 2310962733469
348 2340063841752
349 2347334353000
350 2358505397304
351 2363561613000
352 2405075828688
353 2432457216000
354 2449928032552
355 2482317864000
356 2492666459136
357 2523988807704
358 2550016603827
359 2551153526712
360 2556932049000
361 2560850045208
362 2563722069272
363 2579121784512
364 2607883852329
365 2622104000000
366 2630387160576
367 2641403314368
368 2641692748968
369 2662897521375
370 2669167709208
371 2703367387539
372 2714716265625
373 2724941294712
374 2746367559000
375 2748648357000
376 2749359375000
377 2752055194616
378 2766487751937
379 2799353321821
380 2824798826304
381 2826563023557
382 2838891188224
383 2868488404992
384 2880906054208
385 2885557541013
386 2922399437832
387 2950732202112
388 2958354795753
389 3031368604992
390 3035413143000
391 3049922611008
392 3080802816000
393 3083220189504
394 3092655384000
395 3145900506903
396 3152401132608
397 3153233388032
398 3180672907776
399 3214859387103
400 3235261176000
401 3257431605125
402 3266269461000
403 3276900499320
404 3290217425101
405 3294660096000
406 3294708371136
407 3310615094976
408 3396649098752
409 3440645393976
410 3463400997000
411 3490020424000
412 3499524728000
413 3502364760531
414 3515089379256
415 3519161120384
416 3538534597696
417 3551186093247
418 3561658900875
419 3569691322008
420 3581579460375
421 3587273530659
422 3588164903232
423 3601356189704
424 3623721192000
425 3715934711671
426 3747878552061
427 3753248302125
428 3777864076224
429 3799153291752
430 3839960904507
431 3842642332529
432 3862651968000
433 3877315533000
434 3926408822784
435 3938530307257
436 3951822522375
437 3980164886208
438 3987892421000
439 3996009598392
440 4009377370752
441 4036466508984
442 4042093117608
443 4043945820824
444 4056193761984
445 4066022744000
446 4072658256576
447 4084234467264
448 4085263066248
449 4100548548096
450 4106873408904
451 4209155881749
452 4230379828584
453 4278115075689
454 4291464051000
455 4305951200096
456 4306132625256
457 4341081995523
458 4352829656896
459 4360583872125
460 4434129125307
461 4495065455979
462 4530995712000
463 4601486916936
464 4657129551711
465 4657867412968
466 4691029707000
467 4705625014272
468 4709581676352
469 4749664360896
470 4750893000000
471 4802048288856
472 4803457512168
473 4823172906552
474 4842207939968
475 4848277078125
476 4868489178000
477 4964037656256
478 4991690261376
479 5050790774848
480 5121296875000
481 5126099534829
482 5137474923000
483 5160706974423
484 5169163027392
485 5170538042560
486 5192744863761
487 5203596626235
488 5241994569000
489 5257134155448
490 5323627266048
491 5354763987456
492 5375785332736
493 5383741263992
494 5422497850224
495 5430045170368
496 5444469635904
497 5517107812125
498 5544709352000
499 5546817995264
500 5590531312128
501 5602516416000
502 5608541044288
503 5613673271544
504 5627828177361
505 5628841813656
506 5644222581816
507 5687897700303
508 5688696640536
509 5758773764751
510 5760762488000
511 5765824512000
512 5888920084992
513 5897445363712
514 5902970576328
515 5910127180776
516 5977625518592
517 6027449029056
518 6033297404799
519 6047178729984
520 6069469790664
521 6157033462125
522 6160692787704
523 6181274468161
524 6212251773000
525 6261104152576
526 6261790219776
527 6317197654824
528 6323438583000
529 6362433912744
530 6391060014528
531 6414281000757
532 6434883000000
533 6441085464632
534 6445442643003
535 6450509252096
536 6451359129000
537 6454209728512
538 6455166464448
539 6459120105984
540 6466045107375
541 6485613066072
542 6512786624448
543 6570432559431
544 6575009305536
545 6634080271000
546 6685758144000
547 6695819440128
548 6700001241024
549 6755519396808
550 6768523786752
551 6839840097216
552 6856422961752
553 6913330659144
554 6915892536000
555 6925629745216
556 6959988635733
557 6960803326750'

ary30 = str.split(/\n/).map{|i| i.split(' ')[1].to_i}
Ta4 = 6963472309248
# trueなら4通り以上で表せるものは存在しない
p ary30[-1] < Ta4
ary33 = []
ary30.each{|i|
  ary3 = []
  j, s = 1, 0
  while s < 3
    k = i - j * j * j
    l = (k ** (1.0 / 3)).round
    if k == l * l * l
      ary3.push([j, l])
      s += 1
    end
    j += 1
  end
  ary33.push(ary3)
}
ary33.each{|i|
  i0 = i[1][0] ** 3 + i[1][1] ** 3
  j0 = i[0][0] ** 3 + i[1][0] ** 3 + i[2][0] ** 3 - i0
  if j0 > 0
    if j0 % 2 == 0
      a0 = j0 / 2
      p [a0, i[0][0] ** 3 - a0, i[1][0] ** 3 - a0, i[2][0] ** 3 - a0]
    end
  end
  j1 = i[0][0] ** 3 + i[1][0] ** 3 + i[2][1] ** 3 - i0
  if j1 > 0
    if j1 % 2 == 0
      a1 = j1 / 2
      p [a1, i[0][0] ** 3 - a1, i[1][0] ** 3 - a1, i[2][1] ** 3 - a1]
    end
  end
}

出力結果
true
[1493580092, 2510949380, 7071213244, 51114333631]
[11948640736, 20087595040, 56569705952, 408914669048]
[40326662484, 67795633260, 190922757588, 1380087008037]
[95589125888, 160700760320, 452557647616, 3271317352384]

0 件のコメント:

コメントを投稿

注: コメントを投稿できるのは、このブログのメンバーだけです。