ส่งออกหมายเลขที่สมบูรณ์แบบที่ n


16

ท้าทาย

กำหนดจำนวนเต็ม n เป็นอินพุทที่ไหน0 <= n <= 2^10เอาท์พุทตัวเลขที่สมบูรณ์แบบ n

ตัวเลขที่สมบูรณ์แบบ

ตัวเลขสมบูรณ์แบบคือตัวเลข x โดยที่ผลรวมของปัจจัย (ยกเว้นตัวเอง) เท่ากับ x ตัวอย่างเช่น 6:

6: 1, 2, 3, 6

และแน่นอนว่า1 + 2 + 3 = 6ดังนั้น 6 จึงสมบูรณ์แบบ

ถ้าเป็นจำนวนที่สมบูรณ์แบบเป็นแม้กระทั่งxx mod 2 = 0

ตัวอย่าง

ต่อไปนี้เป็นตัวเลขที่สมบูรณ์แบบ 10 อันดับแรก:

6
28
496
8128
33550336
8589869056
137438691328
2305843008139952128
2658455991569831744654692615953842176
191561942608236107294793378084303638130997321548169216

โปรดทราบว่าคุณอาจจัดทำดัชนีสิ่งนี้ตามที่คุณต้องการ: 6 อาจเป็นหมายเลขที่สมบูรณ์แบบที่ 1 หรือ 0

การชนะ

รหัสที่สั้นที่สุดในหน่วยไบต์ชนะ


2
@LeakyNun ฉันคิดว่านั่นเป็นคำถามเปิด หากคำถามนี้ถูกส่งออกจำนวนที่สมบูรณ์แบบคี่ที่ n ... คุณจะต้องได้รับพันล้านตัวแทนเพื่อให้ได้รับการแก้ไข blogs.ams.org/mathgradblog/2013/07/25/odd-perfect-numbers-exist (ไม่มีอยู่ต่ำกว่า 10 ^ 300)
Rohan Jhunjhunwala

1
จำนวนที่สมบูรณ์แบบคี่ที่เล็กที่สุดคืออะไร?
Leun Nun

5
เป็นเลขคู่nเป็น IFF ที่สมบูรณ์แบบมีเซนเนนายกพีดังกล่าวที่n = P (P + 1) / 2 ไม่มีสูตรดังกล่าวสำหรับตัวเลขสมบูรณ์แบบคี่; ยิ่งไปกว่านั้นมันไม่เป็นที่ทราบแน่ชัดว่ามีตัวเลขสมบูรณ์ที่แปลก
Dennis

2
ไม่มาก มีจำนวนเฉพาะ49 ครั้งที่ Mersenne รู้จัก
Dennis

1
@BetaDecay: มันสูงกว่า $ 49 $ ดังนั้นจึงไม่มีใครรู้หมายเลขที่สมบูรณ์แบบที่ 60
Ross Millikan

คำตอบ:


7

เยลลี่ขนาด 7 ไบต์

6Æṣ=$#Ṫ

ลองออนไลน์!

มันทำงานอย่างไร

6Æṣ=$#Ṫ  Main link. Argument: n

6        Set the return value to 6.
     #   Execute the link to the left with argument k = 6, 7, 8, ... until n
         values of k result in a truthy value. Yield the array of matches.
    $        Combine the two links to the left into a monadic chain.
 Æṣ              Compute the sum of k's proper divisors.
   =             Compare the result with k.
      Ṫ  Tail; extract the last match.

ตัวอาคารจำนวนมากเกี่ยวกับตัวหาร ...
Erik the Outgolfer

6

Mathematica ขนาด 13 ไบต์

ไม่น่าแปลกใจที่มีในตัว

PerfectNumber

ตัวอย่าง:

In[1]:= PerfectNumber[18]                                                       

Out[1]= 33570832131986724437010877211080384841138028499879725454996241573482158\

>    45044404288204877880943769038844953577426084988557369475990617384115743842\

>    47301308070476236559422361748505091085378276585906423254824947614731965790\

>    74656099918600764404702181660294469121778737965822199901663478093006075022\

>    35922320184998563614417718592540207818507301504509772708485946474363553778\

>    15002849158802448863064617859829560720600134749556178514816801859885571366\

>    09224841817877083608951191123174885226416130683197710667392351007374503755\

>    40335253147622794359007165170269759424103195552989897121800121464177467313\

>    49444715625609571796578815564191221029354502997518133405151709561679510954\

>    53649485576150660101689160658011770193274226308280507786835049549112576654\

>    51011967045674593989019420525517538448448990932896764698816315598247156499\

>    81962616327512831278795091980742531934095804545624886643834653798850027355\

>    06153988851506645137759275553988219425439764732399824712438125054117523837\

>    43825674443705501944105100648997234160911797840456379499200487305751845574\

>    87014449512383771396204942879824895298272331406370148374088561561995154576\

>    69607964052126908149265601786094447595560440059050091763547114092255371397\

>    42580786755435211254219478481549478427620117084594927467463298521042107553\

>    17849183589266903954636497214522654057134843880439116344854323586388066453\

>    13826206591131266232422007835577345584225720310518698143376736219283021119\

>    28761789614688558486006504887631570108879621959364082631162227332803560330\

>    94756423908044994601567978553610182466961012539222545672409083153854682409\

>    31846166962495983407607141601251889544407008815874744654769507268678051757\

>    74695689121248545626112138666740771113961907153092335582317866270537439303\

>    50490226038824797423347994071302801487692985977437781930503487497407869280\

>    96033906295910199238181338557856978191860647256209708168229116156300978059\

>    19702685572687764976707268496046345276316038409383829227754491185785965832\

>    8888332628525056

ฉันคิดว่ามีช่องโหว่มาตรฐานสำหรับเรื่องนี้?
Paŭlo Ebermann

1
@ PaŭloEbermannแก้ไขโดยมี 19 downvotes และความคิดเห็นที่มี 94 upvotes ที่อนุมัติ: codegolf.meta.stackexchange.com/a/1078/32933
ทิม

4

MATL , 15 ไบต์

`@Z\s@E=vtsG<}n

ช้ามาก. มันพยายามเพิ่มตัวเลขทีละตัวจนกว่าจะพบจำนวนสมบูรณ์แบบn -th

ลองออนไลน์!

คำอธิบาย

`        % Do...while
  @      %   Push iteration index, k (starting at 1)
  Z\     %   Array of divisors
  s      %   Sum
  @E     %   Push k. Multiply by 2
  =      %   Equal? If so, k is a perfect number
  v      %   Concatenate vertically. This gradually builds an array which at the k-th
         %   iteration contains k zero/one values, where ones indicate perfect numbers
  ts     %   Duplicate. Sum of array
  G<     %   Push input. Less than? This is the loop condition: if true, proceed with
         %   next iteration
}        % Finally (execute right before exiting loop)
  n      %   Number of elements of the array
         % End (implicit). Display (implicit)



2

Python 2 , 198 153 83 78 77 75 74 ไบต์

i=input()
j=0
while i:j+=1;i-=sum(x*(j%x<1)for x in range(1,j))==j
print j

ลองออนไลน์!

ตอนนี้มันอ่านเหมือน psuedocode

  • บันทึก45ไบต์นับไม่ถ้วนเพราะ @Leaky Nun สอนฉันเกี่ยวกับฟังก์ชันผลรวมและรายการความเข้าใจ

  • บันทึก 2 ไบต์ด้วยคำแนะนำของ @ shooqie เพื่อลบวงเล็บที่ไม่จำเป็นออก

เราแค่วนซ้ำทุกเลขคู่จนกว่าเราจะพบตัวเลขสมบูรณ์แบบ


แจ้งให้ทราบว่าคุณเป็นจริงเพียงg sum
Leun Nun

@LeakyNun ให้บริการฉันอย่างถูกต้องเพราะไม่ทราบว่ามีไลบรารีไพ ธ อน ฉันควรเรียนรู้มากกว่าแค่ java และ SILOS
Rohan Jhunjhunwala




2

PHP, 111 ไบต์

0 การจัดทำดัชนี

ทำงานร่วมกับแนวคิดที่ว่าจำนวนที่สมบูรณ์แบบเป็นจำนวนที่n=x*y x=2^iและy=2^(i+1)-1และ y จะต้องมีความสำคัญ

for(;!$r[$argn];$u?:$r[]=$z)for($z=2**++$n*($y=2**($n+1)-1),$u=0,$j=1;$j++<sqrt($y);)$y%$j?:$u++;echo$r[$argn];

ลองออนไลน์!




1

Haskell, 61 ไบต์

(!!)(filter(\x->x==sum[n|n<-[1..x-1],x`mod`n==0]||x==1)[1..])

เนื่องจากดัชนีสามารถเริ่มต้นที่ 0, ||x==1คุณไม่จำเป็นต้อง นอกจากนี้คุณยังสามารถบันทึกไบต์ด้วยการย้าย!!ก่อนวงเล็บปิดเพื่อสร้างส่วนโอเปอเรเตอร์และแทนที่filterด้วยความเข้าใจในรายการอื่น
faubi



0

Clojure, 79 ไบต์

#(nth(for[i(range):when(=(apply +(for[j(range 1 i):when(=(mod i j)0)]j))i)]i)%)

ตามข้อกำหนดการใช้งานหนักสำหรับ:whenเงื่อนไขของ

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.