कुछ हीरे को डबल करें


25

संकट

एक सकारात्मक पूर्णांक को देखते हुए nजहांn < 100

एक हीरे का पैटर्न निम्नानुसार है:

इनपुट n=1

/\/\
\/\/

इनपुट n=2:

 /\      /\
//\\/\/\//\\
\\//\/\/\\//
 \/      \/

इनपुट n=3:

  /\                /\
 //\\  /\      /\  //\\
///\\\//\\/\/\//\\///\\\
\\\///\\//\/\/\\//\\\///
 \\//  \/      \/  \\//
  \/                \/

इनपुट n=4:

   /\                              /\
  //\\    /\                /\    //\\
 ///\\\  //\\  /\      /\  //\\  ///\\\
////\\\\///\\\//\\/\/\//\\///\\\////\\\\
\\\\////\\\///\\//\/\/\\//\\\///\\\\////
 \\\///  \\//  \/      \/  \\//  \\\///
  \\//    \/                \/    \\//
   \/                              \/

और इसी तरह।

नियम

  • कार्यक्रम और समारोह की अनुमति दी।
  • अनुगामी व्हाट्सएप की अनुमति दी।
  • बिना /या \अनुमति के तर्ज पर व्हाट्सएप का नेतृत्व करना ।
  • अनुगामी और अग्रणी नई सूचियों की अनुमति है।
  • बाइट्स में सबसे छोटा कोड जीत जाता है

यह शायद बहुत संबंधित है


2
@carusocomputing आप अभी मतिभ्रम कर रहे हैं ...
निकोलस


1
@dzaima इसके साथ सैंडबॉक्स में!
मैजिक ऑक्टोपस Urn

1
@carusocomputing ज़रूर, लेकिन पहले मुझे यह पता लगाना है कि ऐसा क्यों और कैसे हुआ: p
dimaima

जवाबों:


12

SOGL V0.12 , 24 बाइट्स

ā.∫ā;∫ \*+}ø┼↔±╬¡;øΚ┼}╬³

यह कोशिश करो!

स्पष्टीकरण:

ā                         push an empty array (the main canvas)
 .∫                  }    iterate over the input, pushing 1-indexed iteration
   ā;                       push an empty array below the iteration
     ∫    }                 iterate over the iteration counter
       \*                     push current iteration amount of slashes
         +                    append those to the 2nd array
           ø┼               append nothing (so it'd space the array to a square)
             ↔±             reverse horizontally (swapping slashes)
               έ           quad-palindromize with 0 overlap and swapping characters as required
                 ;          get the canvas ontop
                  øΚ        prepend to it an empty line (so the now bigger romb would be one up)
                    ┼       append horizontally the canvas to the current romb
                      ╬³  palindromize horizontally with no overlap and swapping characters

2
वाह, यह एक बीमार आदेश है।
मैजिक ऑक्टोपस Urn

@carusocomputing सुंदर हाल ही में इसके अलावा। प्रासंगिक फ़ाइल । अभी भी यह पता लगाना है कि शेष १ ९ ० पात्रों के साथ क्या करना है
द्विज

वाह, तो आपके पास एसओजीओएल में 190 मुफ्त कमांड हैं और आप पहले से ही इसे कुशलता से गोल्फ कर सकते हैं?
मैजिक ऑक्टोपस Urn

1
@carusocomputing मैं के लिए 190 मुक्त आदेशों का मतलब lol
dzaima

2
@carusocomputing लेकिन एक मजेदार तथ्य के रूप में, (लगभग) 90/256 वर्ण लागू नहीं होते हैं और 61/256 के पास कोई दस्तावेज नहीं है
dzaima

7

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

F⁺¹N«Fι«F⁴«↙⁻ικ↑⟲T»←»Mι←»‖M

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

ध्यान दें कि चारकोल के बाद से विस्तारित किया गया है और एक अन्य बाइट का उपयोग करके बचाया जा सकता है Increment


आप की जरूरत है जब 0.5 चर आंदोलनों कहाँ कर रहे हैं :(
कैलकुलेटर

6

एपीएल (डायलॉग) , 70 69 66 बाइट्स

B←{'/\ '['\/'⍳⍺⍺⍵]}
C←⊢,⌽B
C(⊢⍪⊖B)⊃,/{C⊖A↑⊖' /'[⍵≤∘.+⍨⍳⍵+1]}¨⌽⍳A←⎕

इसे ऑनलाइन आज़माएं!

मान लिया जाता है ⎕IO←0, जो कई प्रणालियों पर मानक है, इसलिए कार्यक्रम 0-अनुक्रमित है।

यह एक ट्रेडफ़न है जो STDIN के माध्यम से इनपुट लेता है।

व्याख्या

(थोड़ा पुराना)

ध्यान दें कि बाएं तर्क है, सही तर्क है और ⍺⍺बाएं ऑपरेटर है।

Bएक ऐसा कार्य है जो हीरों को चमकाने में मदद करता है। यह स्ट्रिंग को दाएं तर्क के रूप में और रिवर्स फ़ंक्शन को बाएं के रूप में लेता है (इसलिए Bएक ऑपरेटर है)।

B←{'/\ '['\/'⍳⍺⍺⍵]}
              ⍺⍺⍵            Apply ⍺⍺ on 
         '\/'               Find the index of the reflected string in '\/' (if the character is not found in `'\/'`, then return an index out of the bounds of the string, ie `2` if the character is a space)
   '/\ '[        ]           Use these indexes on '/\ ' to reflect the '/\' characters

और अब हम कार्यक्रम के मुख्य भाग में जाते हैं।

A←⎕              Assign the input to variable A
                Create a range 0 .. A-1
                Reverse it so that it becomes A-1 .. 0
¨                For each element do (the right argument is the element):
 ⍳⍵+1             Create a range 0 .. 
 ∘.+⍨             Create an addition table using the range to result in a matrix like so:
                   0+0 0+1 0+2 .. 0+⍵
                   1+0 1+1 1+2 .. 1+⍵
                   2+0 2+1 2+2 .. 2+⍵
                   ...
                   ⍵+0 ⍵+1 ⍵+2 .. ⍵+⍵
 ⍵≤              The elements of the matrix that are greater than or equal to the ⍵,
                 this creates a triangle matrix that looks like this:
                   0 0 .. 0 1
                   0 0 .. 1 1
                   ..
                   1 1 .. 1 1
 ' /'[...]       Index it in ' /' to get a character matrix
                 (ie replace 0s with spaces and 1s with '/'s)
                Flip this vertically
 A              Pad the top spaces

यह सुनिश्चित करने के लिए आवश्यक है कि रेंज में प्रत्येक तत्व के लिए बनाए गए सभी त्रिकोणों की ⌽⍳Aऊंचाई समान है ताकि उन्हें बाद में एक-दूसरे के साथ मिलाया जा सके।

                Flip the matrix vertically again to go back to the original state
 (⊢,  )          Concatenate it with
    B           itself, but flipped horizontally
,/              Concatenate all triangles formed by the range operator
               The resulting matrix is nested, so this operator "un-nests" it

अब पैटर्न का ऊपरी भाग पूरा हो गया है। जो कुछ शेष है, उसे लंबवत और फिर क्षैतिज रूप से फ्लिप करना है।

(⊢⍪⊖B)          Concatenate the resulting matrix with itself but flipped vertically
                (the vertically flipped matrix is concatenated below of the original matrix)
                Now the left part of the pattern is complete
(⊢,⌽B)         Concatenate the resulting matrix with itself flipped horizontally

और बस! आउटपुट /\एस के साथ एक चरित्र मैट्रिक्स है और रिक्त स्थान के साथ गद्देदार है।


6

05AB1E , 47 43 41 35 34 33 32 बाइट्स

'/×ηηvy∞.C.Bø€∞¹NαGð.ø}})øíJ.B»∞

इसे ऑनलाइन आज़माएं!

(-4 बाइट्स के लिए धन्यवाद @Emigna जिन्होंने 3 सुधार सुझाए)


यह स्पष्टीकरण पहले के संस्करण के लिए था, तब से कुछ पुनरावृत्तियों हुए हैं।

>                                          # [2]
 '/×                                       # ['//']
    η                                      # ['/','//']
     €η                                    # [['/'], ['/', '//']]
       vy                    }             # {For each element...}
         ∞                                 # Mirror horizontally.
          ¶¡                               # Split mirror on newlines.
            N£                             # Shave each diamond down a layer.
              .C                           # Horizontal center.
                .B                         # Pad for the transpose.
                  ø                        # Transpose.
                   €∞                      # Mirror each (vertically).
                     ¹NαFð.ø}              # Pad each list for transpose (verticaly).
                              )            # Wrap back to list...
                               €.B         # Pad each horizontally.
                                  ¦        # Remove the random numbers?
                                   ø       # Back to horizontal...
                                    €R     # Reverse to get correct order.
                                      J    # Join, no spaces.
                                       »   # Join newlines.
                                        ∞  # Final horizontal mirror.

आपके हीरे के बीच रिक्त स्थान हैं
LiefdeWen

@LiefdeWen क्या यह ठीक है? अनुगामी और नई सुर्खियों के साथ?
मैजिक ऑक्टोपस Urn

आप ηप्रत्ययों के बजाय उपसर्गों का उपयोग कर सकते हैं क्योंकि वे इस स्ट्रिंग के लिए समान हैं।
इमीना

¨यहाँ जैसा है और वैसा ही €Rहै í
इमिग्ना

@Eignigna मैं उस में से कुछ बाहर गोल्फ, लेकिन धन्यवाद! आप एक 33 बाइट उत्तर का प्रयास करने जा रहे हैं जो 100% अलग है: P?
मैजिक ऑक्टोपस Urn

5

सीजेएम , 65 63 बाइट्स

q~_,:)_W%\+f{_2*S*a@2$-*\_,f{)'/*\Se[_W%'/'\er+}_W%Wf%+1$++}zN*

इसे ऑनलाइन आज़माएं!

व्याख्या

इस स्पष्टीकरण में, मैं इनपुट संख्या के रूप में संदर्भित करूंगा n

q~        e# Read and eval the input (push n to the stack).
_,        e# Copy it an get the range [0 .. n-1].
:)        e# Increment each element to get [1 .. n].
_W%       e# Copy it and reverse it.
\+        e# Prepend the reverse to the original range, resulting in [n n-1 .. 1 1 .. n-1 n].
f{        e# Map over each number x in the range using n as an extra parameter:
 _2*S*a   e#  Push a string containing n*2 spaces, and wrap it in an array.
 @2$-     e#  Push n-x.
 *        e#  Repeat the space string from before n-x times.
 \        e#  Bring x back to the top.
 _,       e#  Copy it and get the range [0 .. x-1].
 f{       e#  Map over each number y in this range, using x as an extra parameter:
  )       e#   Increment y.
  '/*     e#   Repeat '/' y times.
  \Se[    e#   Pad the resulting string to length x by adding spaces to the left.
  _W%     e#   Copy the result and reverse it.
  '/'\er  e#   Replace '/' with '\' in that.
  +       e#   Concatenate to the other string. This forms one row of one diamond.
 }        e#  (end map, now we have the top half of a diamond of size x)
 _W%      e#  Copy the half-diamond and reverse it.
 Wf%      e#  Reverse each row.
 +        e#  Concatenate to the top half. Now we have a full diamond of size x.
 1$++     e#  Put the spaces from before at the beginning and end. This is to pad the top
          e#  and bottom of the smaller diamonds.
}         e# (end map)
z         e# Transpose.
N*        e# Join with newlines. Implicit output.

जिज्ञासा से बाहर, e#स्पष्टीकरण में क्यों ?
मैजिक ऑक्टोपस Urn

1
@carusocomputing यह एक टिप्पणी है, इसलिए आप स्पष्टीकरण को स्वयं चला सकते हैं। वास्तव में आवश्यक नहीं है लेकिन really \ _ (ツ) _ /
Business

1
@carusocomputing CJam #में कोई टिप्पणी नहीं है - sourceforge.net/p/cjam/wiki/Basic%20operators/#number-sign - भले ही यह कई अन्य भाषाओं में हो। चूँकि CJam एक गोल्फ भाषा है, सभी एक-वर्ण कमांड का उपयोग गोल्फ-उपयुक्त कार्यक्षमता के लिए किया जाता है। टिप्पणियाँ केवल ungolfed कोड के लिए उपयोगी होती हैं, इसलिए यह 2-वर्ण अनुक्रम का उपयोग करती है, इस प्रकार एक-वर्ण अनुक्रम को कुछ और के लिए मुक्त करती है
जो

3

पायथन 2 , 152 147 143 140 बाइट्स

-1 बाइट संगीतज्ञ 523 के लिए धन्यवाद

n=input()
r=range(n)
r+=r[::-1]
for x,i in enumerate(r):a,b='/\\\/'[i<x::2];s=' '*(n+~i);print''.join((s+a*n)[:n-j]+(b*-~i+s)[j:]for j in r)

इसे ऑनलाइन आज़माएं!

यह सबसे बड़े हीरे के आंतरिक स्तंभों को काटकर छोटे लोगों को बनाने के लिए काम करता है, [0,..,n,n,..,0]जो हटाने के लिए स्तंभों की मात्रा को नियंत्रित करता है।


आप एक सस्ते बाइट को बदल r=r+करr+=
musicman523

3

पायथ, 35 32 बाइट्स

j.tsm+Jm.[yQS*"\/"k\ Sd_M_Js__BS

परीक्षण सूट

यह देखने के लिए कि मेरे और @ लीकन के दृष्टिकोण अलग कैसे होंगे।


3

द्यलोग एपीएल, 46

{⊃,/⍵∘{'/ \'[2+((-⍪⊖)⌽,-)(-⍺)↑∘.≥⍨⍳⍵]}¨(⌽,⊢)⍳⍵}

PPCG में आपका स्वागत है और पहला उत्तर अच्छा है! यह देखते हुए कि यह कैसे dfn है, मैंने {}आपके उत्तर में जोड़ा क्योंकि उन्हें शामिल किया जाना चाहिए।
कृतिका लिथोस


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