"बज़ट" खेल खेलते हैं


56

विजेता: अडित्सु का सीजेएम जवाब ! 25 बाइट्स! अच्छा!

आप अपना जवाब प्रस्तुत करना जारी रख सकते हैं, हालाँकि अब आप जीत नहीं सकते। मूल पद के लिए रखा गया पद:


"बज़ट" खेल एक ऐसा खेल है जहाँ आपको एक संख्या (इस मामले में 500) की गणना करनी चाहिए। हालाँकि, यदि संख्या में 3 है, या 3 से विभाज्य है, तो आप संख्या नहीं कहते हैं। इसके बजाय, आप "बज़ट" कहते हैं।

नियम:

  • आप संख्याओं को हार्ड-कोड नहीं कर सकते।
  • संख्या को केवल निम्न आवश्यकताओं में से कम से कम 1 को संतुष्ट करना है
    • 3 से विभाज्य
    • संख्या में एक 3 होता है
  • किसी प्रकार का विभाजक अनिवार्य है (12bzzt14 की गिनती नहीं है)
  • स्कोर को बाइट्स में मापा जाता है।
  • 1 या 0 (आपने चुना) से शुरू होकर आपको ठीक 500 तक गिनना चाहिए।
  • संख्याओं का आउटपुट होना चाहिए, लेकिन इससे कोई फर्क नहीं पड़ता कि कैसे (उदाहरण के लिए, स्टडआउट, टेक्स्ट फ़ाइल में लिखना, आदि)।
  • 0 3 से विभाज्य हो सकता है या विभाज्य नहीं हो सकता। आप चुन सकते हैं।
  • आप एक समय में संख्याओं को आउटपुट कर सकते हैं (उदाहरण, आउटपुट 1, फिर 2, फिर बज़ट, फिर 4, आदि) या एक बार में सभी (जैसे, आउटपुट 1 2 बज़ट 4 5)।
  • आपको पत्र 3 को "बज़ट" शब्द से बदलना होगा। यह संवेदनशील नहीं है (bZzt, Bzzt, Bzzt सभी ठीक हैं)।

  • यह एक चुनौती है, इसलिए सबसे छोटा कोड जीतता है।
  • यह प्रतियोगिता 30 जून 2014 (पोस्टिंग से 7 दिन) समाप्त हो रही है।

1
इस प्रश्न के प्रयोजनों के लिए, क्या 3 से 0 विभाज्य है?
Οurous

2
क्या यह "बज़" या "बज़्ट" है? आपने अब तक दो बार "बज़" लिखा।
aditsu

3
कृपया स्पष्ट करें। क्या मुझे आउटपुट करना है buzzया bzztदोनों आवश्यकताएं लागू होती हैं? क्या मुझे आउटपुट 12bzzt4या के bzztलिए है 1234?
nyuszika7h

4
के bzztलिए कहूंगा 1234। यह यहाँ एक 'आम' पीने का खेल है (केवल हम अक्सर इसे 7 के साथ करते हैं)
मार्टीएन

66
"मैं 3 से विभाज्य हो सकता हूं या विभाज्य नहीं। आप चुन सकते हैं।" मुझे नहीं लगता कि आप चुन सकते हैं। 0 mod 3 0 है, यह वास्तव में राय का विषय नहीं है।
डेविड कॉनरेड

जवाबों:


33

सीजाम - २५

501{3sI3%<Is-I"bzzt"?N}fI

धन्यवाद हॉवर्ड :)

इसे http://cjam.aditsu.net/ पर आज़माएं

स्पष्टीकरण:

501{…}fIमूल रूप से है for(int I=0; I<501; ++I) {…}
3sस्ट्रिंग के लिए 3 बदल देता है, यानी "3"
I3%है I% 3
<बाईं सबस्ट्रिंग हो जाता है - "3".substring(0, I % 3)- जो कि "" के लिए I% 3 == 0 और "3" अन्यथा
Isधर्मान्तरित Iस्ट्रिंग के लिए
-2 तार के साथ एक सेट अंतर है, एक खाली है, जिसके परिणामस्वरूप स्ट्रिंग iff I% 3 == 0 (पहला स्ट्रिंग खाली था) या Iइसमें 3 अंक
…I"bzzt"?है जैसे … ? I : "bzzt"; पिछले स्ट्रिंग को बूलियन मान के रूप में माना जाता है, जहां "" गलत है और कोई भी अन्य स्ट्रिंग सही
Nहै, एक नई पंक्ति जोड़ता है


आप मेरे गोल्फस्क्रिप्ट समाधान के समान चाल का उपयोग कर सकते हैं और तार्किक और: को बचा सकते हैं 501{3sI3%<Is-I"bzzt"?N}fI
हावर्ड

29

रूबी, ४३

501.times{|a|puts"#{a}"[?3]||a%3<1?:Bzzt:a}

बहुत सीधा।

संपादित करें: एक बाइट को बचाया, हॉवर्ड को धन्यवाद!


1
यदि आप लिखते हैं तो आप एक व्हाट्सएप को बचा सकते हैं "#{a}"[?3]||a%3<1
होवार्ड

@ हावर्ड: वास्तव में, बहुत बहुत धन्यवाद!
वेंटरो

1
इससे भी अधिक अपठनीय लेकिन दुर्भाग्य से एक ही लंबाई "#{a}"[?3[0,a%3]]:।
हावर्ड

3 वर्णों के putsसाथ बदलने pऔर बचाने के बारे में क्या ?
डेविड यूनिक

1
@DavidUnric अपने तर्क पर pकॉल करने का परिणाम प्रिंट करता inspectहै (पुट्स की तुलना में, जो कॉल करता है to_s)। इसलिए मुद्रण के बजाय Bzzt(जो है :Bzzt.to_s), यह प्रिंट करेगा :Bzzt, जो आउटपुट विनिर्देशों से मेल नहीं खाता है।
वेंचरो

25

seq और GNU sed - 42 33 31 30

सीधे डैश में काम करता है, कुछ अन्य गोले को इतिहास के विस्तार को अक्षम करने की आवश्यकता हो सकती है, जैसे कि बैश के साथ set +H:

seq 500|sed 0~3!{/3/!b}\;cbzzt

यह कैसे काम करता है?
nbubis

शेल स्क्रिप्ट में डिफ़ॉल्ट रूप से इतिहास विस्तार अक्षम है।
nyuszika7h

@ nyuszika7h: सच है, लेकिन मुझे उम्मीद है कि कई लोग एक इंटरैक्टिव शेल में जवाब की कोशिश करेंगे।
थोर

1
@nbubis: अद्यतन संस्करण seq के साथ अनुक्रम उत्पन्न करके काम करता है। 0~3!रन {/3/!b}और एक साथ ये एक्ट्रेसेस लाइन को छोड़ते हैं जैसे कि यह विभाज्य नहीं है और इसमें कोई 3 नहीं है। अंतिम बिट बज़्ट के लिए लाइन को "सही" करता है।
थोर

18

डॉस (.com फ़ाइल) पर x86 मशीन कोड - 71 बाइट्स

00000000  31 c9 68 20 24 89 e5 89  c8 bb 03 00 31 d2 f7 f3  |1.h $.......1...|
00000010  85 d2 74 1a 89 c8 b3 0a  31 d2 f7 f3 80 fa 03 74  |..t.....1......t|
00000020  0d 80 c2 30 86 d6 52 44  85 c0 75 ea eb 08 89 ec  |...0..RD..u.....|
00000030  68 7a 74 68 62 7a 89 e2  b4 09 cd 21 89 ec 41 81  |hzthbz.....!..A.|
00000040  f9 f4 01 7e c2 59 c3                              |...~.Y.|

एक सीमांकक के रूप में अंतरिक्ष के साथ stdout करने के लिए आवश्यक आउटपुट प्रिंट करता है; DosBox में समस्याओं के बिना चलाया जा सकता है।

टिप्पणी विधानसभा:

    org 100h

start:
    ; 0 - 500 counter
    xor cx,cx
    ; we'll use the stack as scratch space to build the strings to print
    ; first of all, push ' $' on the stack (in reverse order); this will be
    ; the end of each string we'll print
    push 2420h
    ; save the stack pointer, to get back to this position after each print
    mov bp,sp
mainloop:
    ; first try to divide by three
    mov ax,cx
    mov bx,3
    xor dx,dx
    div bx
    test dx,dx
    ; no remainder => bzzt
    jz bzzt
    ; otherwise, go into the decimal-print loop
    mov ax,cx
divloop:
    ; bh is already at zero due to the mov bx,3 above
    mov bl,10
    xor dx,dx
    ; divide by 10
    div bx
    ; remainder is 3 => bzzt
    cmp dl,3
    je bzzt
    ; convert number to digit
    add dl,'0'
    ; trick: we move the digit to the upper byte of dx: this allows us to
    ; push the whole dx (you cannot do push dl) but to easily kill the
    ; undesidered byte by touching the stack pointer (it will be overwritten
    ; by the next stack operation/ignored by the print)
    xchg dl,dh
    push dx
    inc sp
    ; check is there anything left to print, rinse & repeat
    test ax,ax
    jnz divloop
    ; skip straight to print
    jmp print
bzzt:
    ; since we may be here from inside divloop, reset the stack pointer to
    ; where we left ' $'
    mov sp,bp
    ; push 'bzzt'
    push 747ah
    push 7a62h
print:
    ; print what is on the stack
    mov dx,sp
    mov ah,9h
    int 21h
    ; move us back to ' $'
    mov sp,bp

    ; increment cx and repeat while we are <=500
    inc cx
    cmp cx,500
    jle mainloop
end:
    ; fix back the stack pointer to the original value (=kill the first push)
    pop cx
    ; quit
    ret

5
आदर करना!!!!! गजब का!
योसिको

@yossico: धन्यवाद! :) वास्तव में, यह वास्तव में कुछ खास नहीं है, मुझे यकीन है कि जिन लोगों ने वास्तव में डॉस के लिए असेंबली लिखी है, वे निश्चित रूप से कुछ और बाइट्स को बंद कर सकते हैं।
मट्टियो इटालिया


17

PHP, कोई विभाजक नहीं - 62, 61,59,58,52,49 47

यह नहीं कहता कि उनके बीच एक स्थान / न्यूलाइन / विभाजक होना चाहिए, बिना:

while(++$i<501)echo$i%3*!strpbrk($i,3)?$i:bzzt;

विभाजक के साथ, 68,67,65,64,58 / 55,53 / 52 51/50

while(++$i<501)echo$i%3*!strpbrk($i,3)?$i:bzzt,' '; // 51
while(++$i<501)echo$i%3*!strpbrk($i,3)?$i:bzzt,~õ; // 50
  • बस एक छोटा सा 'धोखा' मिला, इसके बाद echoमुझे थोड़ी सी भी बचत नहीं हुई।
  • एक नई पंक्ति बनाता है
  • एक और छोटा 'धोखा', बज़ को उद्धरण की आवश्यकता नहीं है (इसका परीक्षण किया गया)। जाने का रास्ता नहीं है, लेकिन यह काम करता है।

जावास्क्रिप्ट - 54,51 50

समान सिद्धांत, लेकिन जावास्क्रिप्ट कार्य:

for(i=0;i++<500;)alert(i%3<1|/3/.test(i)?'bzzt':i)

कोष्ठक के लिए @ कोर और () टिप के लिए धन्यवाद। मेरे लिए मेरे ब्राउज़र को कुछ समय के लिए क्रैश कर दिया गया ^ ^
Martijn

Haha। मैंने console.log()स्पष्ट रूप से इसका परीक्षण किया , लेकिन यह कम है।
Martijn

1
आपका जावास्क्रिप्ट समाधान के लिए 501. मायने रखता है
nderscore

1
52 के लिए PHP: 245 char है, थोड़ा-उलटा । <?for(;500>$i++;)echo$i%3*!strpbrk($i,3)?$i:bzzt,~õ;õ\n
प्रिमो

1
आप बदल सकते हैं !strpbrk($1,3)के साथ trim(3,$i)4 बाइट को बचाने के लिए
aross

16

जावास्क्रिप्ट 50 49

-110 बाइट कोर 1024 के लिए धन्यवाद

for(i=0;i++<500;)alert(i%3*!/3/.test(i)?i:'bzzt')

मुझे पता था कि किया जा सकता है! लेकिन पता नहीं कैसे
edc65

1
जब कोई जावास्क्रिप्ट समाधान मेरे लाइवस्क्रिप्ट को मारता है तो आप मेरे चेहरे की कल्पना कर सकते हैं।
nyuszika7h

yout दूसरे समाधान में आप एक & संकेत निकाल सकते हैं और यह अभी भी काम करेगा
user902383

@ user902383 यह बूलियन &&ऑपरेटर के बिना एक वैध परिणाम नहीं है । उदाहरण के लिए: 497 % 3 = 2=> 2 & true = 0=>bzzt
ndscore

for(i=0;++i<501;)alert(!/3/.test(i)*i%3?i:'bzzt')- 49: पी
कोर 1024

11

GolfScript, 30 29 अक्षर

501,{:^`3`^3%<?)'bzzt'^if n}/

गोल्फस्क्रिप्ट में इतना सीधा कार्यान्वयन नहीं है, यहां परीक्षण किया जा सकता है


10

पर्ल, 36

print$_%3&&!/3/?$_:Bzzt,$/for 1..500

संपादित करें: मैं एक पर्ल भिक्षु नहीं हूं, इसलिए कोर 1024 ने अपने जवाब में एक और बाइट को गोल करने में कामयाब रहा है ।


1
का प्रयोग करें say4 बाइट को बचाने के लिए:say$_%3&&!/3/?$_:bzzt for 1..5e2
ज़ैद

@ क्यों 5e2 और 500 नहीं?
नहीं है कि चार्ल्स

@Charles: वे समकक्ष हैं
Zaid

1
@ इतना स्पष्ट क्यों नहीं है?
नहीं कि चार्ल्स

4
@Charles: कोड-गोल्फ चुनौती के संदर्भ में, क्या किसी को भी परवाह करनी चाहिए?
जुनैद

10

सी # (71)

सीधे LinqPad में निष्पादित किया जा सकता है।

for(var i=0;++i<501;)(i%3<1|(i+"").Contains("3")?"buzz":i+"").Dump();

1
आप |तार्किक-या के बजाय बिटवाइज़-या ( ) का उपयोग करके एक चार को बचा सकते हैं ।
जॉनबॉट

@ जॉनबॉट आपके सुझाव के लिए धन्यवाद।
EvilFonti

आप सशर्त के आसपास कोष्ठक को भी हटा सकते हैं।
जॉनबॉट

@ जॉनबॉट: यह बिटवाइज़-या नहीं है। यह (गैर-शॉर्ट-सर्कुलेटिंग) तार्किक-या, चूंकि ऑपरेंड बूलियन हैं।
रयान एम

डंप बस LinqPad है, हालांकि, सही? एक आवेदन के रूप में सी # में ऐसा करने के लिए एक एक्सटेंशन विधि को जोड़ना होगा। (और यह 'बज़ट' है न 'बज़' =))
पॉल

9

पायथन (52)

धन्यवाद grc!

for i in range(501):print[i,'Bzzt'][i%3<1or'3'in`i`]

पुराना संस्करण:

print['Bzzt'if'3'in`i`or i%3<1 else`i`for i in range(501)]

1
थोड़ा छोटा:for i in range(501):print[i,'Bzzt'][i%3<1or'3'in`i`]
grc

4
एक चार छोटा:['3'[:i%3]in`i`]
xnor

7

हास्केल: 88 82 80 79

main=mapM_ f[1..500]
f n|n`mod`3<1||'3'`elem`show n=putStrLn"bzzt"
f n=print n

अगर मैं एक उत्तर लिख रहा था तो मैं IO को खोदूंगा और एक स्ट्रिंग मान लौटा दूंगा।
गर्वित हैकेलर

1
तुम भी बदल देना चाहिए ==0साथ<1
गर्व haskeller

इसके अलावा, हाथी को उपसर्ग बनाने की कोशिश करें। मुझे लगता है कि आपको लिखने में सक्षम होना चाहिए elem'3'$show n, जो कि एक छोटा है। या नहीं। मैंने जाँच नहीं की।
गर्वित हैकेलर

@proudhaskeller: कल्पना में कहा गया है कि "नंबर आउटपुट होना चाहिए", इसलिए IO को शामिल करना होगा। और elemउपसर्ग संकेतन में उपयोग करने से कोई वर्ण नहीं बचा है क्योंकि एपोस्ट्रोफ से पहले एक स्थान होना चाहिए; अन्यथा आप प्राप्त करेंगे Not in scope: elem'3'<1हालांकि के साथ अच्छी आंख !
टेलर फॉसक

6

जावास्क्रिप्ट 66 63 60

for(a=i=[];i<500;)a[i++]=i%3&&!/3/.test(i)?i:'bzzt';alert(a)

सरणी का उपयोग करने के सुझाव के लिए edc65 का धन्यवाद । आउटपुट अब अल्पविराम से अलग हो जाएगा।


पुराने संस्करणों

संस्करण 1 ए - 66

नियम के अनुसार एक अलर्ट बॉक्स में 1 से 500 तक प्रिंट करें। आउटपुट स्पेस-अलग है।

a="";for(i=1;i<501;i++)a+=i%3&&!/3/.test(i)?i+" ":"bzzt ";alert(a)

संस्करण 1 बी - 65

यदि हम 0 को 3 से विभाज्य नहीं मानते हैं, तो हम 65 वर्णों के समाधान को छोटा कर सकते हैं:

a=0;for(i=1;i<501;i++)a+=i%3&&!/3/.test(i)?" "+i:" bzzt";alert(a)

संस्करण 2 - 63

for(a=i="";i<501;)a+=++i%3&&!/3/.test(i)?i+" ":"bzzt ";alert(a)

लंबाई कम करने के सुझाव के लिए grc का धन्यवाद ।


1
मुझे लगता है कि आप शुरू कर सकते हैंfor(a=i="";i<500;)a+=++i ...
grc

मैंने अल्पविराम का उत्पादन ठीक किया है, एक सरणी छोटी होगी: (o = i = []? मैं <500?) O [i ++] = i% 3 && /! / 3 / .est (i)? I: 'btt' ; अलर्ट (ओ)
edc65

6

पॉवरशेल, 42

1..500|%{($_,'bzzt')[$_-match3-or!($_%3)]}

ज्यादातर मेरे द्वारा सिंटैक्स पर थोड़ी मदद के साथ वेंटरो का काम ;-)


6

आर, ४ ९ अक्षर

a=1:500;b='bzzt';a[!a%%3]=b;a[grep(3,a)]=b;cat(a)

व्याख्या की:

a=1:500 #Creates a vector with all integers from 1 to 500
b='bzzt'
a[!a%%3]=b #Replace all multiples of 3 by 'bzzt', thus coercing all other integers to character strings
a[grep(3,a)]=b #Replaces the character strings containing 3 by 'bzzt'
cat(a) #Print to stdout

उपयोग:

> a=1:500;b='bzzt';a[!a%%3]=b;a[grep(3,a)]=b;cat(a)
1 2 bzzt 4 5 bzzt 7 8 bzzt 10 11 bzzt bzzt 14 bzzt 16 17 bzzt 19 20 bzzt 22 bzzt bzzt 25 26 bzzt 28 29 bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt 40 41 bzzt bzzt 44 bzzt 46 47 bzzt 49 50 bzzt 52 bzzt bzzt 55 56 bzzt 58 59 bzzt 61 62 bzzt 64 65 bzzt 67 68 bzzt 70 71 bzzt bzzt 74 bzzt 76 77 bzzt 79 80 bzzt 82 bzzt bzzt 85 86 bzzt 88 89 bzzt 91 92 bzzt 94 95 bzzt 97 98 bzzt 100 101 bzzt bzzt 104 bzzt 106 107 bzzt 109 110 bzzt 112 bzzt bzzt 115 116 bzzt 118 119 bzzt 121 122 bzzt 124 125 bzzt 127 128 bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt 140 bzzt 142 bzzt bzzt 145 146 bzzt 148 149 bzzt 151 152 bzzt 154 155 bzzt 157 158 bzzt 160 161 bzzt bzzt 164 bzzt 166 167 bzzt 169 170 bzzt 172 bzzt bzzt 175 176 bzzt 178 179 bzzt 181 182 bzzt 184 185 bzzt 187 188 bzzt 190 191 bzzt bzzt 194 bzzt 196 197 bzzt 199 200 bzzt 202 bzzt bzzt 205 206 bzzt 208 209 bzzt 211 212 bzzt 214 215 bzzt 217 218 bzzt 220 221 bzzt bzzt 224 bzzt 226 227 bzzt 229 bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt 241 242 bzzt 244 245 bzzt 247 248 bzzt 250 251 bzzt bzzt 254 bzzt 256 257 bzzt 259 260 bzzt 262 bzzt bzzt 265 266 bzzt 268 269 bzzt 271 272 bzzt 274 275 bzzt 277 278 bzzt 280 281 bzzt bzzt 284 bzzt 286 287 bzzt 289 290 bzzt 292 bzzt bzzt 295 296 bzzt 298 299 bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt 400 401 bzzt bzzt 404 bzzt 406 407 bzzt 409 410 bzzt 412 bzzt bzzt 415 416 bzzt 418 419 bzzt 421 422 bzzt 424 425 bzzt 427 428 bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt bzzt 440 bzzt 442 bzzt bzzt 445 446 bzzt 448 449 bzzt 451 452 bzzt 454 455 bzzt 457 458 bzzt 460 461 bzzt bzzt 464 bzzt 466 467 bzzt 469 470 bzzt 472 bzzt bzzt 475 476 bzzt 478 479 bzzt 481 482 bzzt 484 485 bzzt 487 488 bzzt 490 491 bzzt bzzt 494 bzzt 496 497 bzzt 499 500

6

कोबरा - 70

class P
    def main
        for i in 501,print if('3'in'[i]'or i%3<1,'Bzzt',i)

बैच - 222

क्योंकि मैं वास्तव में इस भाषा से प्यार करता हूँ ... किसी कारण से ...

SETLOCAL ENABLEDELAYEDEXPANSION
for /l %%n in (1,1,500) do (
    set a=%%n&set /ai=!a!%%3
    if "!a:~0,1!"=="3" set a=Bzzt
    if "!a:~1,2!"=="3" set a=Bzzt
    if "!a:~2,3!"=="3" set a=Bzzt
    if !i!==0 set a=Bzzt
    echo !a!>>x)

आपको पहले ऑपरेंड के आसपास उद्धरण चिह्नों को छोड़ने में सक्षम होना चाहिए ifक्योंकि आप जानते हैं कि कम से कम एक अंक है। forसाथ &ही कोष्ठक को बचाने के लिए काम कर सकते हैं के साथ पूरा ब्लॉक concatenating ।
जॉय

इसके अलावा, आप के ==बजाय का उपयोग कर सकते हैं EQUऔर शायद यहाँ और वहाँ कुछ रिक्त स्थान ड्रॉप।
जॉय

@ जोये सुझाव के लिए धन्यवाद!
.सुर

6

TI-BASIC - 31 (32) (34) (35) (36) (43)

:While X<500
:X+1→X
:If not(fPart(X/3
:"bzzt
:Disp Ans
:End

Total: 25 + 6 lines = 31

ध्यान दें कि TI-BASIC पर अधिकांश आदेश एकल-बाइट संस्थाओं के रूप में दर्शाए गए हैं।

कोड को पहले से 0 पर आरंभीकृत करने की आवश्यकता होती है (अन्यथा, यह एक अतिरिक्त 3 बाइट्स है)।

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


मुझे सही अगर मैं गलत हूँ, लेकिन यह प्रतीत नहीं होता है bzzt3 की, जैसे 13. युक्त संख्या
थोर

@ आप सही हैं, लेकिन मैं नियमों के भीतर हूं, क्योंकि वे कहते हैं कि मैं bzztकेवल उन संख्याओं के लिए प्रिंट कर सकता हूं जो 3 से विभाज्य हैं। दूसरे तरीके को जोड़ना संभव हो सकता है, लेकिन अधिक निर्देशों की आवश्यकता होगी।
डॉकटोरो रीचर्ड

1
नियम कहते हैं: यदि संख्या में 3 है, या 3 से विभाज्य है, तो आप संख्या नहीं कहते हैं। इसके बजाय, आप "बज़ट" कहते हैं , इसलिए मैं कहूंगा कि दोनों को प्रतिस्थापित किया जाना चाहिए।
थोर

@ जो मुझे सबसे ज्यादा परेशान करता है, वह है कि सजा के बीच में नन्हा नन्हा कॉमा। जिस तरह से मैंने इसकी व्याख्या की है, करने के दोनों तरीके समान रूप से मान्य हैं, जो दूसरे नियम को भी बताता है: संख्या को केवल 1 आवश्यकताओं को पूरा करना होगा ... (या तो 3 है या 3 से विभाज्य होना चाहिए)
डॉकटोरो रीचर्ड

1
आपने यहां बाइट्स को मिस किया क्योंकि लोअरकेस अक्षर दो-बाइट टोकन हैं। मैं थोर के नियमों की व्याख्या से सहमत हूं क्योंकि यह वह है जो इसके ऊपर दिए गए प्रत्येक उत्तर का उपयोग करता है।
lirtosiast

5

सी, 93

बस नरक के लिए...

main(i){char s[9]="bzzt";while(i<498+sprintf(s+5,"%d",i))puts(s+5*(i++%3&&!strchr(s+5,51)));}

इसकी एक छोटी सी गड़बड़ है - यह आउटपुट के लिए i = 0
स्केच करता है

4
@anatolyg "आपको 1 या 0 (आपने चुना है) से शुरू होने वाली 500 तक की गिनती सही होनी चाहिए।" - मैं 1 से शुरू करने के लिए चुना
स्क्वीश ossifrage

उस बिट को याद किया। माफ़ करना!
अनातोली

यदि आप इसे तर्क देते हैं, तो बहुत अधिक छोड़ देता है। लेकिन, यह अच्छी तरह से गोल्फ है, मैं तुम्हें दे दूँगा! जब तक आप नियंत्रण करने के लिए तीन अंकों की संख्या की ओर रुझान के रूप में स्प्रिंटफ के रिटर्न मूल्य का उपयोग करने के लिए नीचे जाएं। इतना बुरा .... हाहा!
ड्रीमवर्यर

5

जूलिया 64 बाइट्स

map(x->x%3==0||contains(string(x),"3")?"Bzzt":string(x),[1:500])

2
[println(a%3==0||3 in digits(a)?"bzzt":a) for a=1:500]54 बाइट्स है। किसी सरणी को वापस करने से पूरे सरणी को प्रिंट नहीं किया जाता है, इसलिए मुझे यकीन नहीं है कि यह "आउटपुट" के रूप में गिना जाता है। यदि कोई ऐरे वापस लौटता है, तो [a%3==0||3 in digits(a)?"bzzt":a for a=1:500]गिनती हो सकती है और स्कोर 45 हो सकता है।
gggg

5

cmd.exe - 91

for /l %x in (1,1,500)do @set/a %x%3|find "0">nul&&echo bzzt||echo %x|find/v"3"||echo bzzt

... क्योंकि जब पूरी तरह से एक-लाइनर मौजूद है तो बैच फ़ाइल का उपयोग क्यों होता है ... :-)


5

ग्रूवी - 51

500.times{println"$it".find('3')||it%3<1?'bzzt':it}

संपादित करें: timesमुद्रण संस्करण का उपयोग अब "प्रदर्शन" के रूप में छोटा है। धन्यवाद @ विल-पी


1
+1। आप के (1..500).eachलिए स्वैप कर सकते हैं500.times
विल

4

सी, 80

लाइन ब्रेक के बजाय विभाजक के रूप में रिक्त स्थान का उपयोग करना।

n;main(){for(;n++<500;)printf(n%10^3&&n/10%10^3&&n/100^3&&n%3?"%d ":"bzzt ",n);}

1 bzzt 3 4 bzzt 6 7 bzzt 9 10 bzzt bzzt 13 bzzt... यहाँ कुछ गड़बड़ है।
स्क्विश ओस्सिफ्रेज

ऐसा लगता है कि मैं बहुत लालची था, और अपरिभाषित व्यवहार में ठोकर खा गया (अनुक्रम बिंदुओं के बीच संशोधित और पढ़ा गया)। अब तय हो गया।
अनातोली

अब काम कर रहे :-)
स्क्वीश ossifrage

4

गणितज्ञ, ५४ वर्ण

यह बहुत सीधा लगता है। छोटा समाधान संभव होना चाहिए।

If[DigitCount[#][[3]] > 0 || #~Mod~3 < 1, Bzzt, #] & /@ Range@500

आप apostrophes की जरूरत नहीं है :)
डॉ। Belisarius

@ अविश्वास वास्तव में। धन्यवाद।
माइकल स्टर्न

4

टी-एसक्यूएल 2008 - 80

जीतने के लिए या कुछ भी नहीं लेकिन मज़ा कम नहीं जा रहा है: Tweaked धन्यवाद @domager के लिए:

declare @ int=0t:if(@)like'%3%'or @%3=0print'bzzt'print @;set @+=1if @<501goto t

थोड़ा ज्ञात तथ्य, @ एक चर का एक वैध नाम है। यह अजीब लगता है क्योंकि सेट आधारित कोड अधिक एसक्यूएल संस्करण है, लेकिन छोटा कम है! यह संस्करण किसी भी डेटाबेस पर काम करता है। संपादित करें: मैं उनमें से दो को निकालने में सक्षम था क्योंकि उनकी जरूरत नहीं थी। मुझे पूरा यकीन है कि यह उतना ही इष्टतम है जितना इसे मिलता है।

Edit2: कभी मत कहो। यहाँ यह अब गोटो का उपयोग करने वाला भी है, लेकिन यह हमें ब्लॉक से बचने की अनुमति देता है। हम बदल सकते हैं, जबकि, शुरू, छोटे के साथ अंत अगर, टी:, गोटो 6 पात्रों की बचत। हम लूप को छद्म रूप से करते हुए, फिर से शब्दार्थ के रूप में लूप को फिर से लिखते हैं। Edit3: हाँ, किसी तरह अगर अब कम है। मूल:

select top 501iif(number like'%3%'or number%3=0,'bzzt',str(number))from spt_values where'p'=type

मास्टर डेटाबेस पर चलना चाहिए। मैं टी-एसक्यूएल को इसके शोर और बदसूरत तरीकों के बावजूद प्यार करता हूं। इसे सरल बनाने का एक तरीका हो सकता है, लेकिन दुर्भाग्य से, iifअंतर्निहित दोनों पक्षों को प्रकारों पर सहमत होने की आवश्यकता होती है। Sql सर्वर पूर्वता नियम स्ट्रिंग्स की तुलना में अधिक उच्च वरीयता देते हैं। संख्या भी वास्तव में लंबी है, लेकिन अलियासिंग इसके लायक होने की तुलना में अधिक वर्ण है। संख्या को स्ट्रिंग में बदलने का एक बेहतर तरीका हो सकता है। संपादित करें: str कार्य भी। Ltrim की तुलना में 2 कम वर्ण


पहले मुझे लगा कि आपका कोड 2012.96 बाइट्स लंबा है।
nyuszika7h

थोड़ी देर में @ 101, लेकिन एक मेज पर भरोसा नहीं करताdeclare @i int=1;while(@i<501)begin;if(@i)like'%3%'or @i%3=0 print'bzzt'else print @i;set @i=@i+1 end
डोम

@domager, पूरी तरह से सही है, साथ ही हम वैरिएबल को स्विच करके काफी कुछ अक्षर बचा सकते हैं @। तब iif का उपयोग करना () अभी भी अगर (...) प्रिंट की तुलना में छोटा है, तो हम iifअभिव्यक्ति का उपयोग करके काफी लाभ प्राप्त करते हैं। इसके अलावा हम @+=1चार को बचाने के लिए छोटे का उपयोग कर सकते हैं
माइकल बी

मुझे नहीं पता था कि T-SQL समर्थित है +=। मेरे पास इसका परीक्षण करना आसान नहीं है, लेकिन मुझे पूरा यकीन है कि यह ''+@अपरिवर्तनीय लोकेल का उपयोग करके स्ट्रिंग रूपांतरण के लिए समर्थन करता है ।
पीटर टेलर

+=2008 में जोड़ा गया था। यह '' @ का समर्थन करता है, लेकिन यह वह नहीं करता है जो आप चाहते हैं। जैसा कि मैंने कहा, पूर्वता के नियम पहले ''int के लिए डाले जाते हैं , इसलिए यह int को डाली जाती है , जिसके परिणामस्वरूप शून्य ''+@को @अभी भी एक के रूप में टाइप किया जाता है intstrकाम करता है और यह किसी भी चीज की तुलना में बहुत अधिक महंगा नहीं है (2 अतिरिक्त चार्ट के लिए)। मैंने IIFऑपरेटर के कारण यहां 2012 में टी-एसक्यूएल को चुना , जो जानता है कि शायद 2016 की रिलीज एसक्यूएल को कुछ शोर से छुटकारा मिलेगा और प्रतिस्पर्धी (संभावनाहीन) होना शुरू हो जाएगा।
माइकल बी

4

VBA: 54

for x=0to 500:?iif(x/3=x\3=instr(1,x,3),x,"Bzzt"):next

अपने पसंदीदा कार्यालय कार्यक्रम को खोलें, VBA IDE खोलने के लिए alt + F11 को हिट करें और कोड को तत्काल फलक में पेस्ट करें और एंटर दबाएं।

VBA में: रेखा विभाजक है,? प्रिंट के लिए आशुलिपि है, आईआईएफ का अर्थ है इनलाइन यदि (थिंक x? "Y": "N"), x / 3 फ्लोटिंग पॉइंट डिवीजन करता है और x \ 3 पूर्णांक विभाजन करता है, तो instr एक स्ट्रिंग में चार की स्थिति में रिटर्न करता है, या 0 अन्यथा, सत्य = -1 और असत्य = 0।

कोड मूल रूप से x को बढ़ाता है और x को आउटपुट करता है यदि x / 3 = x \ 3 = instr (1, x, 3) सत्य है और अन्यथा "Bzzt" है। x / 3 = x \ 3 तुलना (फ्लोट) (x / 3) से (int) (x / 3) और एक बूलियन देता है (0 गलत है और -1 सच है)। instr (1, x, 3) 0 देता है यदि "3" संख्या में नहीं है, और एक सकारात्मक पूर्णांक अन्यथा। केवल तभी अभिव्यक्ति सही होती है जब x (3/3 = x \ 3) गलत हो (0) और इंस्ट्र (1, x, 3) 0 हो, या दूसरे शब्दों में, जब x 3 से विभाज्य नहीं है और नहीं है "3" अंक को समाहित करें, जो वास्तव में हम देख रहे हैं।


4

k4 (37) (35)

{$(x;`bzzt)(|/51=$x)|~"."in$x%3}'!501

k4एक अंतर्निहित मोडुलो कमांड का अभाव है, और qएक का उपयोग करके एक अतिरिक्त चरित्र ले जाएगा; यह संस्करण (एब) अंतर्निहित आउटपुट प्रारूप का उपयोग करता है यह जांचने के लिए xकि क्या 3 के विभाजन के परिणाम की स्ट्रिंग में दशमलव बिंदु है।

संपादित करें:

{$(x;`bzzt)(|/51=$x)|x=3*_x%3}'!501

दशमलव बिंदु के मिलान के रूप में चतुर हो सकता है, मैं 3*floor x%3अभी भी जाँच करके दो बाइट्स दाढ़ी कर सकता हूं x


दशमलव बिंदु को चतुराई से मिलान करने के लिए अपग्रेड किया गया!
मार्क

कृपया अपने सभी उत्तरों को अपडेट न करें। यह सामने पृष्ठ से सभी सक्रिय चुनौतियों को धक्का देगा। यह अच्छा होगा यदि आप केवल एक या दो बार करते हैं। (हालांकि मैं भी नहीं के बीच बदलते लगता है h1और h2काफी महत्वपूर्ण पहली जगह में एक संपादन वारंट है।)
मार्टिन Ender

3

दे घुमा के, ५३ ५२ ४ 53 46

seq 500|factor|sed '/3.*:\| 3 */cBzzt
s/:.*//'

GNU sed की आवश्यकता है ( cएक्सटेंशन का उपयोग करता है )।


3

जावा, 142 131 वोज़्जेसी सुझाव के लिए धन्यवाद

public class a{public static void main(String[]a){for(int i=1;i<501;i++)System.out.println(i%3>0&(""+i).indexOf(51)<0?i:"bzzt");}}

1
मेरा जावा थोड़ा कठोर है। लेकिन यह एक और ऑपरेंड के साथ कम नहीं होगा? i% 3> 0 && ("" + i) .indexOf (51) <0? i: "bzzt"। यह भी संभव हो सकता है कि फ़ोरलूप के लिए {} को छोड़ दें।
वोज़ज़ेक

यह 122 बाइट्स, 9 कम है:class A{public static void main(String[]a){for(int i=0;++i<501;System.out.println(i%3>0&(""+i).indexOf(51)<0?i:"bzzt"));}}
लुइगी कोर्टीज

3

आर (40) (36)

यह मूल रूप से प्लेनैपस थोड़ा छोटा जवाब है, लेकिन मैं अभी तक टिप्पणी नहीं कर सकता

अपडेट: -4 अक्षर (देखें प्लानअपस की टिप्पणी)

a=1:500;a[grepl(3,a)|!a%%3]='bzzt';a

आउटपुट:

  [1] "1"    "2"    "bzzt" "4"    "5"    "bzzt" "7"    "8"    "bzzt" "10"   "11"   "bzzt" "bzzt" "14"   "bzzt" "16"   "17"   "bzzt" "19"   "20"   "bzzt" "22"   "bzzt" "bzzt" "25"   "26"   "bzzt" "28"   "29"   "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "40"   "41"   "bzzt" "bzzt" "44"   "bzzt" "46"   "47"   "bzzt" "49"   "50"   "bzzt" "52"   "bzzt" "bzzt" "55"   "56"   "bzzt" "58"   "59"   "bzzt" "61"   "62"   "bzzt" "64"   "65"   "bzzt" "67"   "68"   "bzzt" "70"   "71"   "bzzt" "bzzt" "74"   "bzzt" "76"   "77"   "bzzt" "79"   "80"   "bzzt" "82"   "bzzt" "bzzt" "85"   "86"   "bzzt" "88"   "89"   "bzzt" "91"   "92"   "bzzt" "94"   "95"   "bzzt" "97"   "98"   "bzzt" "100"  "101"  "bzzt" "bzzt" "104"  "bzzt" "106"  "107"  "bzzt" "109"  "110"  "bzzt" "112"  "bzzt" "bzzt" "115"  "116"  "bzzt" "118"  "119"  "bzzt" "121"  "122"  "bzzt" "124"  "125"  "bzzt" "127"  "128"  "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "140"  "bzzt" "142"  "bzzt" "bzzt" "145"  "146"  "bzzt" "148"  "149"  "bzzt" "151"  "152"  "bzzt" "154"  "155"  "bzzt" "157"  "158"  "bzzt" "160"  "161"  "bzzt" "bzzt" "164"  "bzzt" "166"  "167"  "bzzt" "169"  "170"  "bzzt" "172"  "bzzt" "bzzt" "175"  "176"  "bzzt" "178"  "179"  "bzzt" "181"  "182"  "bzzt" "184"  "185"  "bzzt" "187"  "188"  "bzzt" "190"  "191"  "bzzt" "bzzt" "194"  "bzzt" "196"  "197"  "bzzt" "199"  "200"  "bzzt" "202"  "bzzt" "bzzt" "205"  "206"  "bzzt" "208"  "209"  "bzzt" "211"  "212"  "bzzt" "214"  "215"  "bzzt" "217"  "218"  "bzzt" "220"  "221"  "bzzt" "bzzt" "224"  "bzzt" "226"  "227"  "bzzt" "229"  "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "241"  "242"  "bzzt" "244"  "245"  "bzzt" "247"  "248"  "bzzt" "250"  "251"  "bzzt" "bzzt" "254"  "bzzt" "256"  "257"  "bzzt" "259"  "260"  "bzzt" "262"  "bzzt" "bzzt" "265"  "266"  "bzzt" "268"  "269"  "bzzt" "271"  "272"  "bzzt" "274"  "275"  "bzzt" "277"  "278"  "bzzt" "280"  "281"  "bzzt" "bzzt" "284"  "bzzt" "286"  "287"  "bzzt" "289"  "290"  "bzzt" "292"  "bzzt" "bzzt" "295"  "296"  "bzzt" "298"  "299"  "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "400"  "401"  "bzzt" "bzzt" "404"  "bzzt" "406"  "407"  "bzzt" "409"  "410"  "bzzt" "412"  "bzzt" "bzzt" "415"  "416"  "bzzt" "418"  "419"  "bzzt" "421"  "422"  "bzzt" "424"  "425"  "bzzt" "427"  "428"  "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "bzzt" "440"  "bzzt" "442"  "bzzt" "bzzt" "445"  "446"  "bzzt" "448"  "449"  "bzzt" "451"  "452"  "bzzt" "454"  "455"  "bzzt" "457"  "458"  "bzzt" "460"  "461"  "bzzt" "bzzt" "464"  "bzzt" "466"  "467"  "bzzt" "469"  "470"  "bzzt" "472"  "bzzt" "bzzt" "475"  "476"  "bzzt" "478"  "479"  "bzzt" "481"  "482"  "bzzt" "484"  "485"  "bzzt" "487"  "488"  "bzzt" "490"  "491"  "bzzt" "bzzt" "494"  "bzzt" "496"  "497"  "bzzt" "499"  "500"

चूंकि कई स्ट्रिंग ऑपरेशन फ़ंक्शन (जैसे कि strsplit) गैर-वर्णों के साथ खिलाए जाने पर त्रुटि फेंकते हैं जो मैंने भी किया greplथा। अच्छा पकड़ा! +1
प्लेनैपस

2
वैसे जब से आपने इसे कम करके एक एक्सप्रेशन दिया है, उससे पहले आपको इसे परिभाषित करने की आवश्यकता नहीं bहै:a=1:500;a[grepl(3,a)|!a%%3]='bzzt';a
प्लेनैपस

3

फोरट्रान - 118 114 111

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

do3 i=1,500
j=i
if(mod(i,3))2,1,2
1 print*,'bzzt'
cycle
2 goto(1)mod(j,10)-2
j=j/10
if(j>0)goto2
3 print*,i
end

"कंप्यूटेड गोटो" goto(L1,L2,...,Ln) xशाखाओं में से किसी एक में L यदि और केवल 1 <= x <= n है तो।

संपादित करें: अंक के लिए जांच करने वाले लूप को फिर से व्यवस्थित करके 4 बाइट्स से दाढ़ी बनाने का प्रबंधन। 3. एक बोनस के रूप में, कोड में अब अंकगणितीय इफ-स्टेटमेंट भी शामिल है if(x) a,b,c, जो हमेशा तीन लेबलों में से एक पर शाखा करता है: एक अगर x <0, b अगर x == 0 या c अगर x> 0।

दुर्भाग्य से, पहले दो संस्करणों ने सही आउटपुट नहीं दिया। अंक -3 लूप अब सही ढंग से काम करता है, और कोड में अब एक आधुनिक तार्किक इफ-स्टेटमेंट भी शामिल है। तीन और बाइट चले गए हैं, क्योंकि किसको एक enddoबयान की जरूरत है ? आउटपुट को यहां सत्यापित किया जा सकता है ।

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.