यह bulking मौसम है


12

मेरे जिम के बारबेल इस तरह दिखते हैं:

=========[]-----------------------[]=========

वे पांच अलग-अलग आकारों की प्लेट, 2.5 पाउंड, पांच पाउंड, दस पाउंड, 25 पाउंड और 45 पाउंड पकड़ सकते हैं:

                .
        .   !   |
.   !   |   |   |
|   |   |   |   |
'   !   |   |   |
        '   !   |
                '

सुरक्षा के लिए, हम अपने सभी प्लेटों के बाहर ]या [बाहर एक क्लिप जोड़ते हैं यदि कोई हो। बार का वजन 45 पाउंड है। हम हमेशा केंद्र के सबसे नज़दीकी सबसे भारी प्लेटों को रखते हैं, जिसमें किसी भी प्लेट के बीच कोई अंतराल नहीं होता है, और दोनों तरफ समान प्लेट्स डालते हैं। हम हमेशा संभव प्लेटों की न्यूनतम संख्या का भी उपयोग करते हैं, उदाहरण के लिए, हम कभी भी एक एकल दस-पाउंड प्लेट के बजाय एक तरफ दो पांच पाउंड प्लेट का उपयोग नहीं करते हैं। तो अगर मैं 215 पाउंड उठाना चाहता हूं, तो मेरा बार ऐसा दिखता है:

        .                           .
      .!|                           |!.
     !|||                           |||!
====]||||[]-----------------------[]||||[====
     !|||                           |||!
      '!|                           |!'
        '                           '

आपका कोड, एक फ़ंक्शन या पूरा कार्यक्रम, 45 से 575 तक पूर्णांक होना चाहिए, हमेशा 5 से अधिक, और उस भार को जोड़ने वाले बार का उत्पादन करता है। उदाहरण के लिए:

इनपुट: 45

आउटपुट (ध्यान दें कि खाली पट्टी पर कोई क्लिप नहीं है):

=========[]-----------------------[]=========

इनपुट: 100

आउटपुट:

        !                           !
       .|                           |.
======]||[]-----------------------[]||[======
       '|                           |'
        !                           !

इनपुट: 575

आउटपुट:

    .....                           .....
  .!|||||                           |||||!.
 !|||||||                           |||||||!
]||||||||[]-----------------------[]||||||||[
 !|||||||                           |||||||!
  '!|||||                           |||||!'
    '''''                           '''''

प्रत्येक पंक्ति में आपके पास अनुगामी स्थान हो सकता है या नहीं, लेकिन आपके आउटपुट में खाली रेखाएँ नहीं हो सकती हैं या पीछे नहीं जा सकती हैं (45 के लिए आउटपुट एक पंक्ति होनी चाहिए, 50 के लिए तीन पंक्तियाँ होनी चाहिए, 65 के लिए पाँच पंक्तियाँ होनी चाहिए, और इसी तरह)

यह कोड गोल्फ है, सबसे छोटा कोड जीतता है!


क्या हमें हर मामले के लिए 7-उच्चियों सहित एक अनुगामी खाली रेखा को प्रिंट करने की अनुमति है, जैसे कि पायथन का उपयोग करके स्ट्रिंग को मुद्रित किया गया था print?
PurkkaKoodari

जवाबों:


1

पायथ, 126 बाइट्स

K[Z5TyT50 90)jfrT6.e::++J+?qk3\=dsm@bxKdhfqQ+45sTSSM^K8?qk3r"[]23-[]"9*27d_J"=\|""]|""\|=""|["c7s@L". !|='"jC"¾ª±À£¤¯aàI7"6

स्रोत कोड में अनपेक्षित वर्ण हैं, इसलिए यहां यह XXD डंप के रूप में है:

0000000: 4b5b 5a35 5479 5435 3020 3930 296a 6672  K[Z5TyT50 90)jfr
0000010: 5436 2e65 3a3a 2b2b 4a2b 3f71 6b33 5c3d  T6.e::++J+?qk3\=
0000020: 6473 6d40 6278 4b64 6866 7151 2b34 3573  dsm@bxKdhfqQ+45s
0000030: 5453 534d 5e4b 383f 716b 3372 225b 5d32  TSSM^K8?qk3r"[]2
0000040: 332d 5b5d 2239 2a32 3764 5f4a 223d 5c7c  3-[]"9*27d_J"=\|
0000050: 2222 5d7c 2222 5c7c 3d22 227c 5b22 6337  ""]|""\|=""|["c7
0000060: 7340 4c22 2e20 217c 3d27 226a 4322 04be  s@L". !|='"jC"..
0000070: aa1f b1c0 a3a4 81af 61e0 4937 2236       ........a.I7"6

यह कोड बेहद धीमा है , बिना किसी वास्तविक उपयोग के। कोड को कार्यात्मक रूप से समतुल्य रखते हुए, बीच में .{( set) कॉल जोड़कर आप इसे लगभग 1000 गुना बढ़ा सकते हैं । यहां परिणामी कोड का कॉपी-पेस्ट फ्रेंडली संस्करण है:

K[Z5TyT50 90)jfrT6.e::++J+?qk3\=dsm@bxKdhfqQ+45sTS.{SM^K8?qk3r"[]23-[]"9*27d_J"=\|""]|""\|=""|["c7s@L". !|='"j96235640060099376576144045263159 6

2

पायथन 2, 295 बाइट्स

i=input()-45
w=90,50,20,10,5;p=".|||||'"," !|||! "," .|||' ","  !|!  ","  .|'  "
a=[' '*46]
b=zip(*a*3+['='*9+'[]'+'-'*24+'[]'+'='*9]+a*3)
v=8
j=0
while i:
 if i>=w[j]:i-=w[j];b[v]=b[-v-1]=p[j];v-=1
 else:j+=1
if v<8:b[v]=b[10];b[-v-1]=b[9]
for l in zip(*b):
 L=''.join(l).rstrip()
 if L:print L

बार को लंबवत बनाता है, फिर गैर-रिक्त लाइनों को घुमाता है और प्रिंट करता है।


-v-1बिटवाइज़ नकार के लिए एक प्रमुख उम्मीदवार है; ~v
जोनाथन फ्रीच

1

चारकोल , 65 बाइट्स

¹²[]P×=⁹≔⁻N⁴⁵θWΦ⟦⁵χ²⁰¦⁵⁰¦⁹⁰⟧¬›κθ«P|§⪪”{⊞⧴&β1←Z↶RΣ”,Lι→P[≧⁻⊟ιθ»‖B←

इसे ऑनलाइन आज़माएं! लिंक कोड के वर्बोज़ संस्करण के लिए है। स्पष्टीकरण:

¹²[]P×=⁹

प्रिंट 12 -एस, []और 9 =एस। इसमें बार का आधा हिस्सा शामिल है। कर्सर को शुरुआत में छोड़ दिया जाता है =

≔⁻N⁴⁵θ

बार के वजन की अनुमति देने के लिए इनपुट से 45 घटाएं।

WΦ⟦⁵χ²⁰¦⁵⁰¦⁹⁰⟧¬›κθ«

उन वज़न के संभावित वज़न की सूची को उन लोगों के लिए फ़िल्टर करें जो इनपुट से अधिक नहीं हैं, और सूची खाली नहीं होने पर दोहराएं।

P|§⪪”{⊞⧴&β1←Z↶RΣ”,Lι

|||.,|.,|!,||.,||!कॉमा पर स्ट्रिंग को विभाजित करें और सबसे भारी संभव वजन के अनुरूप टुकड़े का चयन करें, और इसे ऊपर और नीचे दोनों तरफ प्रिंट करें। (वैकल्पिक रूप से, इसे केवल ऊपर की तरफ प्रिंट करना और ¬अंत में दिशा में प्रतिबिंबित करना संभव है ; कई विविधताओं की लंबाई समान है।)

→P[

क्लिप प्रिंट करें (अगले वजन से अधिलेखित हो जाएगा यदि कोई हो)।

≧⁻⊟ιθ»

इनपुट से वजन घटाना।

‖B←

बारबेल को पूरा करने के लिए प्रतिबिंबित करें।

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