Polygoner er opkaldt efter antallet af sider, de har. En femkant har 5 sider, en ottekant har 8 sider. Men hvordan hedder de? Hvad er navnet på en 248-sidet polygon?
Alle polygoner er efterfulgt af -gon
. Der er specifikke præfikser for hver polygon afhængigt af antallet af sider Her er præfikser for de lavere tal:
3 - tri 4 - tetra 5 - penta 6 - hexa 7 - hepta 8 - octa 9 - nona 10 - deca 11 - undeca 12 - dodeca 13 - triskaideca 14 - tetradeca 15 - pentadeca 16 - hexadeca 17 - heptadeca 18 - octadeca 19 - nonadeca 20 - icosa
Polygoner med 21 til 99 sider har et andet system. Tag præfikset til ti-cifret (findes på venstre kolonne), cifrene (højre kolonne nedenfor), og hold derefter en “kai” mellem dem for at få (tens)kai(ones)gon
.
10 - deca | 1 - hena 20 - icosi | 2 - di 30 - triaconta | 3 - tri 40 - tetraconta | 4 - tetra 50 - pentaconta | 5 - penta 60 - hexaconta | 6 - hexa 70 - heptaconta | 7 - hepta 80 - octaconta | 8 - octa 90 - nonaconta | 9 - nona
De 3-cifrede polygoner er navngivet på en lignende måde. En 100-sidet polygon kaldes en hektogon. Tag hundreder cifret, find det i kolonnen for de cifre, og sæt derefter en “hekta” til højre. Tal nu de tiere som dem ovenover: (hundreds)hecta(tens)kai(ones)gon
. Hvis tallet hundreder er et 1, skal du ikke sætte præfikset bag “hekta”; hvis ens sted er 0, skal du udelade sektionen (dem).
Så givet et heltal (3 < = n < = 999), returner navnet på en n-sidet polygon. n-gon
er ikke et gyldigt svar: P
Som med al kodegolf vinder den korteste kode.
Kommentarer
Svar
C, 401 , 391
Lad os lægge noget derude, så der er mindst et svar til reference 🙂
char*s[]={"","hena","di","tri","tetra","penta","hexa","hepta","octa","nona","un","do","triskai","deca","icosi","tria","conta","kai","icosa","hecto","hecta","gon\n"}; p(i){printf(s[i]);} t;n(i){ if(i<10) p(i); // ones else if(i<20){ i-=10; p(i+(i&&i<4)*9); // teens p(13); // "deca" }else if(i==20) p(18); // "icosa" else if(i==100) p(19); // "hecto" else{ t=i/100; p(t>1?t:0); // hundreds p(t?20:0); // "hecta" i%=100; t=i/10; p(t+(t&&t<4)*12); // tens p(t>2?16:0); // "conta" i%=10; p(i?17:0); // "kai" p(i); // ones } p(21); // "gon\n" }
Test med:
main(){ for(int i=3;i<=999;i++){ printf("%3d: ",i);n(i); } }
Delsæt af output:
3: trigon 4: tetragon 5: pentagon 6: hexagon 7: heptagon 8: octagon 9: nonagon 10: decagon 11: undecagon 12: dodecagon 13: triskaidecagon 14: tetradecagon 15: pentadecagon 16: hexadecagon 17: heptadecagon 18: octadecagon 19: nonadecagon 20: icosagon 21: icosikaihenagon 22: icosikaidigon 23: icosikaitrigon ... 99: nonacontakainonagon 100: hectogon 101: hectakaihenagon 102: hectakaidigon 103: hectakaitrigon 104: hectakaitetragon 105: hectakaipentagon 106: hectakaihexagon 107: hectakaiheptagon 108: hectakaioctagon 109: hectakainonagon 110: hectadecagon 111: hectadecakaihenagon ... 997: nonahectanonacontakaiheptagon 998: nonahectanonacontakaioctagon 999: nonahectanonacontakainonagon
Kommentarer
- Dejligt. Du kan erstatte
if..else
med?:
(og;
med,
) for at gemme nogle tegn. Ogsåt>1&&p(t)
og lignende ændringer kan hjælpe. Og jeg ' er ikke sikker, men måske kan du omarrangeres
, så de konstanter, du bruger, er ensifrede.
Svar
JavaScript – 405 386
Version 1: (405 tegn)
i=prompt(),o="0hena0di0tri0tetra0penta0hexa0hepta0octa0nona".split(0),d="0W0icosi0triaQ0tetraQ0pentaQ0hexaQ0heptaQ0octaQ0nonaQ".split(0),t="W0unW0doW0triskaiW0tetraW0pentaW0hexaW0heptaW0octaW0nonaW0icosa".split(0),x=("000"+i).substr(-3).split("");alert((i<10?o[i]:i<21?t[i-10]:i==100?"hecto":(i<100?"":i<200?"hecta":o[x[0]]+"hecta")+d[x[1]]+"kai"+o[x[2]]).replace(/Q/g,"conta").replace(/W/g,"deca")+"gon")
Version 2: (386 tegn)
i=prompt(),p="0tetra0penta0hexa0hepta0octa0nona",o="0hena0di0tri"+p,t=("W0unW0doW0triskai"+p.replace(/0/g,"W0")+"W0icosa").split(0),x=("000"+i).substr(-3).split(""),o=o.split(0);alert((i<10?o[i]:i<21?t[i-10]:i==100?"hecto":(i<100?"":i<200?"hecta":o[x[0]]+"hecta")+("0W0icosi0tria"+p.replace(/0/g,"Q0")+"Q").split(0)[x[1]]+"kai"+o[x[2]]).replace(/Q/g,"conta").replace(/W/g,"deca")+"gon")
Eksempel på output:
3: trigon 4: tetragon 5: pentagon 6: hexagon 7: heptagon 8: octagon 9: nonagon 10: decagon 11: undecagon 12: dodecagon 13: triskaidecagon 14: tetradecagon 15: pentadecagon 16: hexadecagon 17: heptadecagon 18: octadecagon 19: nonadecagon 20: icosagon 21: icosikaihenagon 22: icosikaidigon 23: icosikaitrigon 99: nonacontakainonagon ... 100: hectogon 101: hectakaihenagon 102: hectakaidigon 103: hectakaitrigon 104: hectakaitetragon 105: hectakaipentagon 106: hectakaihexagon 107: hectakaiheptagon 108: hectakaioctagon 109: hectakainonagon 110: hectadecakaigon 111: hectadecakaihenagon ... 997: nonahectanonacontakaiheptagon 998: nonahectanonacontakaioctagon 999: nonahectanonacontakainonagon
Svar
Cobra – 370 bytes
Dette er i øjeblikket en funktion, men hvis det ikke er tilladt, ændrer jeg det.
def f(x) as String o=". hena di tri tetra penta hexa hepta octa nona".split o[0],t,h,d="",["","deca","icosci","triconta"],["","hecta","dihecta","trihecta"],["undeca","dodeca","triskaideca"] for z in 4:10,t,h,d=t+[o[z]+"conta"],h+[o[z]+"hecta"],d+[o[z]+"deca"] for z in 10,t[z]+="kai" return if(x-100,h[x//100]+if(10<x<20,d[x-11],t[x%100//10]+o[x%10]),"hecto")+"gon"
Og af en eller anden grund har cobra highlighter //
indstillet som en kommentar, hvilket er forkert.
ennea-
, men jeg ' har hørt " nonagon " oftere end " enneagon ", så jeg gik med det.deca
, tak for at påpege det. 110 – hektadecagon, 120 – hektaikosigon. 101 – hektakaihenagon.