A sokszögeket az oldalak számáról nevezik el. Egy ötszögnek 5, egy nyolcszögnek 8 oldala van. De hogyan nevezik őket? Mi a neve egy 248 oldalú sokszögnek?
Az összes sokszög utótagja a -gon
. Az egyes sokszögekhez vannak külön előtagok, az oldalak számától függően. . Itt vannak az alsó számok előtagjai:
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
A 21–99 oldalú sokszögek rendszere eltér. Vegyük az előtagot a tízes számjegyhez (megtalálható itt: a bal oldali oszlopot), az egy számjegyeket (jobb oldali oszlop lent), majd ragasszon egy “kai” -t közéjük, hogy (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
A háromjegyű sokszögeket hasonló módon nevezik meg. A 100 oldalú sokszöget hektogonnak hívják. Vegyük a százas számjegyet, keressük meg az oszlopban egy számjegyűek után, majd ragasszunk be egy “hektát” jobbra. Most számolja le a tízeseket és a fentieket: (hundreds)hecta(tens)kai(ones)gon
. Ha a százas számjegy 1, akkor ne tegye az előtagot a “hekta” mögé; ha az egyek helye 0, akkor hagyja ki az (egyek) szakaszt.
Tehát adott egy egész szám (3 < = n < = 999) adja vissza az n oldalú sokszög nevét. A n-gon
nem érvényes válasz: P
Mint minden golf-golf esetében, a legrövidebb kód is nyer.
Megjegyzések
Válasz
C, 401 , 391
Lehetővé tesz valamit, hogy legalább egy válasz legyen 🙂
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" }
Tesztelés:
main(){ for(int i=3;i<=999;i++){ printf("%3d: ",i);n(i); } }
A kimenet részhalmaza:
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
megjegyzések
- Szép. A
if..else
szöveget?:
(és;
szöveget ) néhány karakter mentéséhez. At>1&&p(t)
és hasonló változások is segíthetnek. És ' nem vagyok benne biztos, de talán átrendezheted as
t úgy, hogy az általad használt konstansok egyjegyűek legyenek.
Válasz
JavaScript – 405 386
1. verzió: (405 karakterek)
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")
2. verzió: (386 karakter)
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")
Kimeneti példa:
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
Válasz
Cobra – 370 bájt
Ez jelenleg egy függvény, de ha ez nem engedélyezett, akkor megváltoztatom.
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"
Valamilyen oknál fogva a kobra kiemelő //
megjegyzésként beállítva, ami helytelen.
ennea-
, de én ' gyakrabban hallottam " nonagon ", mint " enneagon ", így mentem vele.deca
, köszönöm, hogy felhívta erre a figyelmet. 110 – hektárszög, 120 – hektikusszigon. 101 – hektakaihenagon.