Wielokąty są nazywane według liczby posiadanych boków. Pięciokąt ma 5 boków, ośmiokąt ma 8 boków. Ale jak je nazywają? Jak nazywa się wielokąt o 248 bokach?
Wszystkie wielokąty mają przyrostek -gon
. W zależności od liczby boków istnieją określone przedrostki dla każdego wielokąta . Oto przedrostki niższych liczb:
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
Wielokąty o bokach od 21 do 99 mają inny system. Weź prefiks dla cyfry dziesiątek (znalezionej na lewa kolumna), cyfrę jedności (prawa kolumna poniżej), a następnie umieść między nimi znak „kai”, aby uzyskać (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
Trzycyfrowe wielokąty o bokach nazywane są w podobny sposób. 100-bokowy wielokąt nazywa się hektogonem. Weź cyfrę setek, znajdź ją w kolumnie dla jedności cyfr, a następnie przyklej „hektę” po jego prawej stronie. Teraz odliczaj dziesiątki i jedynki, jak powyżej: (hundreds)hecta(tens)kai(ones)gon
. Jeśli cyfra setek to 1, nie umieszczaj przedrostka za „hecta”; jeśli miejscem jedynek jest 0, pomiń sekcję (jedynki).
Zatem biorąc pod uwagę liczbę całkowitą (3 < = n < = 999), zwraca nazwę wielokąta n-stronnego. n-gon
nie jest prawidłową odpowiedzią: P
Jak w przypadku każdego kodu golfa, wygrywa najkrótszy kod.
Komentarze
Odpowiedź
C, 401 , 391
Umieśćmy tam coś, aby była co najmniej jedna odpowiedź w celach informacyjnych 🙂
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" }
Przetestuj z:
main(){ for(int i=3;i<=999;i++){ printf("%3d: ",i);n(i); } }
Podzbiór wyników:
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
Komentarze
- Świetnie. Możesz zamienić
if..else
na?:
(i;
na,
), aby zapisać kilka znaków. Pomocne mogą być równieżt>1&&p(t)
i podobne zmiany. I ' nie jestem pewien, ale może mógłbyś zmienić kolejnośćs
tak, aby stałe, których używasz, były jednocyfrowe.
Odpowiedź
JavaScript – 405 386
Wersja 1: (405 znaków)
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")
Wersja 2: (386 znaków)
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")
Przykład wyników:
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
Odpowiedź
Cobra – 370 bajtów
Obecnie jest to funkcja, ale jeśli nie jest to „niedozwolone”, zmienię ją.
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"
Z jakiegoś powodu wyróżnienie kobry ma //
jako komentarz, co jest błędne.
ennea-
, ale ' słyszeliśmy " nonagon " częściej niż " enneagon ", więc poszedłem z tym.deca
, dziękujemy za zwrócenie uwagi. 110 – hektadecagon, 120 – hectaicosigon. 101 – hectakaihenagon.