झंडे के साथ मज़ा!


20

256 बाइट्स या उससे कम के स्रोत कोड के साथ एक पूर्ण कार्यक्रम लिखें जो एक ध्वज की छवि को देखता है और यह निर्धारित करता है कि झंडा किस देश से है। चुनौती में 196 अलग-अलग झंडों वाली ज़िप फ़ाइल यहाँ से डाउनलोड की जा सकती है । स्रोत: [ फ्लैगपीडिया ]। ये 196 ध्वज चित्र केवल इनपुट हैं जिन्हें आपके प्रोग्राम को संभालना है।

आपके कार्यक्रम में कोई इनपुट नहीं लिया जाएगा। ध्वज चित्र आपके प्रोग्राम के समान निर्देशिका में होगा और "f.png" नाम दिया जाएगा। आपका प्रोग्राम इस फ़ाइल को खोलेगा, इसकी पहचान करेगा और उस देश के लिए दो अक्षर का संक्षिप्त नाम प्रिंट करेगा । यदि आप ऐसी भाषा का उपयोग करते हैं जो फाइलें नहीं खोल सकती हैं, तो यह आपके प्रोग्राम को चलाने के लिए भी स्वीकार्य है ./program < f.png

प्रत्येक ध्वज फ़ाइल को अपेक्षित आउटपुट के रूप में नाम दिया गया है। 2 अक्षरों से ऊपर के सभी आउटपुट को नजरअंदाज कर दिया जाएगा।

यहाँ सभी आउटपुट / फ़ाइलनाम की सूची दी गई है:

ad, ae, af, ag, al, am, ao, ar, at, au, az, ba, bb, bd, be, bf, bg, bh, bi, bj,
bn, bo, br, bs, bt, bw, by, bz, ca, cd, cf, cg, ch, ci, cl, cm, cn, co, cr, cu,
cv, cy, cz, de, dj, dk, dm, do, dz, ec, ee, eg, eh, er, es, et, fi, fj, fm, fr,
ga, gb, gd, ge, gh, gm, gn, gq, gr, gt, gw, gy, hn, hr, ht, hu, id, ie, il, in,
iq, ir, is, it, jm, jo, jp, ke, kg, kh, ki, km, kn, kp, kr, ks, kw, kz, la, lb,
lc, li, lk, lr, ls, lt, lu, lv, ly, ma, mc, md, me, mg, mh, mk, ml, mm, mn, mr,
mt, mu, mv, mw, mx, my, mz, na, ne, ng, ni, nl, no, np, nr, nz, om, pa, pe, pg,
ph, pk, pl, pt, pw, py, qa, ro, rs, ru, rw, sa, sb, sc, sd, se, sg, si, sk, sl,
sm, sn, so, sr, st, sv, sy, sz, td, tg, th, tj, tl, tm, tn, to, tr, tt, tv, tw,
tz, ua, ug, us, uy, uz, va, vc, ve, vn, vu, ws, ye, za, zm, zw, 

स्कोरिंग

यहाँ एक छोटी अजगर स्क्रिप्ट है जिसका उपयोग मैं प्रत्येक सबमिशन स्कोर करने के लिए करूँगा।

import os
import subprocess
import random

botlist = []
with open("bots.txt") as bots:
    for line in bots:
        line = line.split(", ")
        if len(line) >= 2:
            botLine = line + [0]
            botlist.append(botLine)

files = os.listdir(os.getcwd() + "/flags")
random.shuffle(files)

def test(bot_command):
    score = 0
    for filename in files:
        command = "COPY flags\\{} f.png".format(filename)
        os.system(command)

        print bot_command

        result = subprocess.check_output(bot_command, shell = True)
        if result[:2] == filename[:2]:
            score += 1

    return score

for i in range(len(botlist)):
    command = botlist[i][1]
    botlist[i][2] = test(command)

with open("output.txt", "w+") as output:
    for bot in botlist:
        output.write("{} got a score of {}.".format(bot[0], bot[2]))

os.system("del f.png")

आपका स्कोर सही पहचाने गए झंडे की कुल संख्या है। एक टाई के मामले में, पहले जमा करने वाला जीत जाता है।

नियम

  • मेरी परीक्षण सुविधा के लिए, विंडोज 10 या उबंटू के लिए स्वतंत्र रूप से उपलब्ध दुभाषिया / संकलक वाली किसी भी भाषा का उपयोग किया जा सकता है।

  • छवि प्रसंस्करण पुस्तकालयों की अनुमति है, लेकिन झंडे या देशों से संबंधित किसी भी निर्माण की अनुमति नहीं है। ( कफ गणितज्ञ खांसी )

  • कृपया किसी भी आवश्यक लाइब्रेरी के लिंक के साथ अपने प्रोग्राम को चलाने के लिए आवश्यक पूर्ण कमांड प्रदान करें।

  • सबमिशन "f.png" को छोड़कर किसी भी फाइल के साथ इंटरैक्ट नहीं कर सकता है।

  • मेरे पास प्रस्तुतियाँ पर कोई कठिन समय-सीमा नहीं है, लेकिन कृपया इसे अपेक्षाकृत जल्दी रखें। मैं स्कोरिंग स्क्रिप्ट को घंटे नहीं लेना चाहता।


4
बाइट की सीमा वास्तव में कम है। बस 196 दो-अक्षर कोडों को संग्रहीत करने के लिए 392 बाइट्स की आवश्यकता होती है
edc65

2
@ edc65 बिंदु यह है कि आप केवल बहुत कम संख्या में झंडे पाने वाले हैं।
आइसाकग

1
@ edc65 मैंने जानबूझकर एक ऐसा नंबर चुना, जो मूल रूप से असंभव 196 का सही स्कोर बना देगा। यह छवियों को पहचानने के बारे में अधिक है तो कोडगोल्फ।
DJMcMayhem

बस दोहरी जाँच - क्या हम केवल ./program < f.pngविकल्प का उपयोग कर सकते हैं यदि भाषा में फ़ाइलों को पढ़ने का कोई तरीका नहीं है, या क्या हम इसका उपयोग तब भी कर सकते हैं जब भाषा फ़ाइलों को पढ़ सकती है? (जाहिरा तौर पर CJam फाइलों से पढ़ सकता है, जो मुझे नहीं पता था)
Sp3000

ये 196 ध्वज चित्र केवल इनपुट हैं जिन्हें आपके प्रोग्राम को संभालना है फिर आप कहते हैं कि आपका प्रोग्राम कोई इनपुट नहीं लेगा । क्या इसका मतलब यह है कि एक फ़ाइल f.png उन 196 में से एक होगी। इसलिए कार्यक्रम उन ज़िप की गई फ़ाइलों का संदर्भ नहीं दे सकता है? बस f.png
मैट

जवाबों:


11

सीजेएम, 139 141

कोड में बहुत सारे xxdunprintables हैं , इसलिए यहाँ hexdump है:

00000000: 7132 3925 3162 226d cec5 9635 b14b 69ee  q29%1b"m...5.Ki.
00000010: d9d0 66e8 97b8 e88d 2366 7857 9595 1c73  ..f.....#fxW...s
00000020: 9324 11b2 ddb8 7a3f 19ed bd37 07c0 cb86  .$....z?...7....
00000030: 394e b34a ecf0 8c9b f300 a216 2e2e 594a  9N.J..........YJ
00000040: 9a6b 3b2f 250a 9a25 783b 0e49 3e9c 6ab9  .k;/%..%x;.I>.j.
00000050: 8d6d d729 42d0 85f3 657b 7d86 af48 c6cb  .m.)B...e{}..H..
00000060: f7ff 980f b81c dd5e e8cb 4e34 d8ec edca  .......^..N4....
00000070: 6646 1b4d 7605 8937 ed58 2302 1cc1 ebfd  fF.Mv..7.X#.....
00000080: 16d3 b53e 3e2c d879 fe33 feef dd65 d49f  ...>>,.y.3...e..
00000090: 5d73 7ced 92e6 9526 c186 00bf d2a8 ffaa  ]s|....&........
000000a0: 65a0 3001 f42a 94d7 592f ebe7 8bdf 97a7  e.0..*..Y/......
000000b0: 0681 8ee1 9e0e 424b f6a1 4c50 1c8a 8de5  ......BK..LP....
000000c0: 481a 388c 6eaa 0c43 e1db 69df 567b 323f  H.8.n..C..i.V{2?
000000d0: 2573 c4ce b348 6fff 37e0 55b4 7c9a 7e7d  %s...Ho.7.U.|.~}
000000e0: 73a4 ef74 2b99 b765 2a2d d99f 986a 355c  s..t+..e*-...j5\
000000f0: db22 3236 3362 3236 6227 6166 2b32 2f3d  ."263b26b'af+2/=

यह बिल्कुल 256 बाइट्स है, जिसमें कार्यक्रम कर रहे हैं:

q29%                          Read input and keep every 29th char
    1b                        Sum code points
      "..."                   Push long string
           263b               Convert long string to base 263
               26b            Convert result to base 26
                  'af+        Add 'a to each element in the resulting array
                      2/      Split into chunks of length 2
                        =     Index sum cyclically to extract output

कमांड के साथ प्रोग्राम चलाएं

java -Dfile.encoding=ISO-8859-1 -jar cjam-0.6.5.jar flags.cjam < f.png

इस सबमिशन के काम में मदद करने के लिए @ डेनिस का धन्यवाद।


मुझे आश्चर्य है कि किसी को भी यह कई मिला। 139/196 = 70.9%। आपने एक ग्रेड को स्क्रैप कर दिया है!
स्तर नदी सेंट

क्या आप बाइनरी डंप को xxd -rअपरिवर्तनीय बना सकते हैं? साइगविन के पास होना चाहिएxxd
बिल्ली

1
@ टैक को थोड़ा इधर-उधर झांकना पड़ा, लेकिन मुझे एहसास नहीं था कि सिग्विन के पास यह नहीं था - मुझे बस इसे मैन्युअल रूप से इंस्टॉलेशन के लिए चुनना था। जब मैं अगली बार उत्तर को अपडेट करूंगा तो मैं इसे अपडेट करूंगा।
Sp3000

मैंने मोर्स कोड के लिए उसी तकनीक का उपयोग करने की कोशिश की , लेकिन मुझे जो सबसे अच्छा मिला है वह 129 झंडे हैं, और मैंने यह भी नहीं जांचा है कि क्या यह 256-बाइट की सीमा में फिट बैठता है। अच्छी तरह से इस तरह के अच्छे हैश को खोजने के लिए किया गया।
पीटर टेलर

12

पायथन 2, स्कोर = 68 89

यह समाधान देश की सूची की सूची में एक सूचकांक बनाने के लिए फ्लैग इमेज फ़ाइल के हैश का उपयोग करता है। यदि एक इंडेक्स में एक से अधिक फ्लैग हैशेड किया गया है, तो केवल पहला संक्षिप्त नाम वापस किया जाएगा (इसलिए यह उन परीक्षणों में से कुछ को एक हैश बकेट में एक से अधिक देशों के साथ विफल कर देगा)। यह एल्गोरिथ्म हालांकि हर गैर-खाली हैश बाल्टी के लिए एक सही उत्तर की गारंटी देता है।

i=hash(open('f.png').read())%99*2
print'kgmviruasefridusvakpsmbtgrpwcdsdauninrsyalsg--game--espyscmtyebhgqom--kh--inhudjbw--ltroilbicv--jonaugke--svhtbg--simcknbnpelcplgncmmacimytnttlytgcflirsvemhtzuyqaerbfbepa--uzaenearcl--jmbbphkzrwieet'[i:i+2]

यह कार्यक्रम 247 वर्णों का है।

अधिक पठनीय संस्करण:

encoded = 'kgmviruasefridusvakpsmbtgrpwcdsdauninrsyalsg--game--espyscmtyebhgqom--kh--inhudjbw--ltroilbicv--jonaugke--svhtbg--simcknbnpelcplgncmmacimytnttlytgcflirsvemhtzuyqaerbfbepa--uzaenearcl--jmbbphkzrwieet'
index = hash(open('f.png').read())%99 * 2
print encoded[index : index+2]

एन्कोडेड स्ट्रिंग का निर्माण

एन्कोडेड स्ट्रिंग बनाने के लिए, मैं फ़्लैग फ़ाइलों को स्ट्रिंग के रूप में पढ़ने के लिए एक फ़ंक्शन का उपयोग करता हूं, स्ट्रिंग से एक हैश उत्पन्न करता हूं, और हैश को सीमित संख्या में हैश करता है buckets:

def encode(buckets):
    lookup = {}
    for fn in os.listdir('flags'):
        name = fn[:2]
        signature = hash(open('flags/'+fn).read()) % buckets
        lookup[signature] = lookup.get(signature, '')+name
    return lookup

प्रत्येक हस्ताक्षर से मेल खाने वाले देशों का शब्दकोश लौटाने के लिए, फिर शब्दकोश को लुकअप स्ट्रिंग में बदलने के लिए कुछ कोड का उपयोग करें:

encoded = ''.join(lookup.get(v, '--')[:2] for v in range(buckets))

मुझे थोड़ा प्रयोग करने की आवश्यकता थी जिसके साथ bucketsसर्वोत्तम परिणाम मिलते हैं।


क्या यह सिर्फ झंडे का औसत रंग ले रहा है?
अश्विन गुप्ता

@ अश्विनगुप्ता, कार्यक्रम फ़ाइल में पढ़ता है, फिर उसका एक हैश लेता है। यह बड़ी हैश संख्या एक modulo ऑपरेटर का उपयोग करके एक स्ट्रिंग सूची में एक सूचकांक में कम हो जाती है।
लॉजिक नाइट

1
यकीन नहीं है कि यह मदद करेगा, लेकिन आप कर सकते हैं print'...'[...:][:2]। इसके अलावा, शायद एक बुनियादी तालिका के साथ >>और &कुछ बुनियादी संपीड़न के लिए?
Sp3000

@ Sp3000, डबल इंडेक्स का विचार दिलचस्प लगता है, लेकिन मैं यह नहीं देख सकता कि यहाँ कोई बाइट्स कहाँ बचेंगे। मैंने संपीड़न के लिए बिट हेरफेर कार्यों पर विचार नहीं किया था, लेकिन यह एक फायदा दे सकता है। Hmmmm।
लॉजिक नाइट

1
डबल अनुक्रमण 3 बाइट्स बचाता है क्योंकि आपको एक चर को बचाने की आवश्यकता नहीं है i, लेकिन आप उन अतिरिक्त बाइट्स का उपयोग कर सकते हैं या नहीं, यह एक अलग सवाल है: P
Sp3000
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.