सुपर एक्रॉस्टिक बनाइए


35

पृष्ठभूमि

Dyalog APL 16.0 की रिलीज़ का जश्न , जहां इस समस्या का समाधान {⊢⌺(≢⍵)⊢⍵}स्पष्टीकरण है

कार्य

एक प्रिंट योग्य ASCII स्ट्रिंग को देखते हुए अजीब लंबाई के एन , एक बनाने n × n तार के साथ वर्ग क्षैतिज रूप से केंद्रित, ऊर्ध्व रूप से केंद्रित किए जाने की दोहराया गया, और प्रत्येक पंक्ति और स्तंभ में एक ही तार का acrostics साथ। ध्यान दें कि वर्ग के आकार n × n को रखने के लिए सभी केन्द्रित तारों को काट दिया जाएगा ।

आपके कोड की व्याख्या बहुत सराहना की जाएगी।

नियम

  1. आपके पास अनुगामी व्हाट्सएप और न्यूलाइन्स हो सकते हैं (इसमें निचला-दायाँ त्रिकोण शामिल है)
  2. आप स्ट्रिंग्स की सूची वापस कर सकते हैं

स्ट्रिंग का उपयोग करके उदाहरण ABXCD:

  • n 5. पहले हम दो केंद्रित तार खींचते हैं, एक क्षैतिज और एक ऊर्ध्वाधर:

    ┌─────┐
    │ ए │
    │ बी │
    │ABXCD│
    │ सी │
    │ डी │
    └─────┘
    

    (5 × 5 बाउंडिंग बॉक्स स्पष्टता के लिए जोड़ा गया)

  • फिर हम क्षैतिज और लंबवत रूप से सभी संभव अस्थानिकों को रखते हैं:

           ए
          एबी
      ┌─────┐
      │ ABX│CD
      │ ABXC│D
      │ABXCD│
     A│BXCD │
    ABXCD │
      └─────┘
       सीडी
       डी
    
  • अंत में, हम केवल वही खाते हैं जो बाउंडिंग बॉक्स के अंदर है:

      ABX
     ABXC
    ABXCD
    BXCD 
    XCD  
    

परीक्षण के मामलों

World:

  Wor
 Worl
World
orld
rld

mississippi:

     missis
    mississ
   mississi
  mississip
 mississipp
mississippi
ississippi
ssissippi
sissippi
issippi
ssippi

Pneumonoultramicroscopicsilicovolcanoconiosis:

                      Pneumonoultramicroscopi
                     Pneumonoultramicroscopic
                    Pneumonoultramicroscopics
                   Pneumonoultramicroscopicsi
                  Pneumonoultramicroscopicsil
                 Pneumonoultramicroscopicsili
                Pneumonoultramicroscopicsilic
               Pneumonoultramicroscopicsilico
              Pneumonoultramicroscopicsilicov
             Pneumonoultramicroscopicsilicovo
            Pneumonoultramicroscopicsilicovol
           Pneumonoultramicroscopicsilicovolc
          Pneumonoultramicroscopicsilicovolca
         Pneumonoultramicroscopicsilicovolcan
        Pneumonoultramicroscopicsilicovolcano
       Pneumonoultramicroscopicsilicovolcanoc
      Pneumonoultramicroscopicsilicovolcanoco
     Pneumonoultramicroscopicsilicovolcanocon
    Pneumonoultramicroscopicsilicovolcanoconi
   Pneumonoultramicroscopicsilicovolcanoconio
  Pneumonoultramicroscopicsilicovolcanoconios
 Pneumonoultramicroscopicsilicovolcanoconiosi
Pneumonoultramicroscopicsilicovolcanoconiosis
neumonoultramicroscopicsilicovolcanoconiosis
eumonoultramicroscopicsilicovolcanoconiosis
umonoultramicroscopicsilicovolcanoconiosis
monoultramicroscopicsilicovolcanoconiosis
onoultramicroscopicsilicovolcanoconiosis
noultramicroscopicsilicovolcanoconiosis
oultramicroscopicsilicovolcanoconiosis
ultramicroscopicsilicovolcanoconiosis
ltramicroscopicsilicovolcanoconiosis
tramicroscopicsilicovolcanoconiosis
ramicroscopicsilicovolcanoconiosis
amicroscopicsilicovolcanoconiosis
microscopicsilicovolcanoconiosis
icroscopicsilicovolcanoconiosis
croscopicsilicovolcanoconiosis
roscopicsilicovolcanoconiosis
oscopicsilicovolcanoconiosis
scopicsilicovolcanoconiosis
copicsilicovolcanoconiosis
opicsilicovolcanoconiosis
picsilicovolcanoconiosis
icsilicovolcanoconiosis

स्वीकृतियाँ

सब कुछ के लिए , लेकिन इस चुनौती का बहुत विचार है , dzaima , लीक नन , श्री Xcoder के लिए धन्यवाद ।


1
क्या नीचे दाईं ओर रिक्त स्थान-त्रिकोण को शामिल किया जाना है या नहीं?
दोष

1
@flawr ओपी: मई
Adám

जवाबों:



5

MATL , 8 बाइट्स

nXyPGZ+c

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

व्याख्या

n    % Implicit input. Number of elements
Xy   % Identity matrix of that size
P    % Flip vertically
G    % Push input again
Z+   % 2D convolution, maintaining size
c    % Convert to char (char 0 is displayed as space). Implicitly display

1
किसने सोचा था कि मुझे यह जवाब पसंद आएगा: D
दोष

1
@flawr हां, किसने सोचा
लुइस मेंडू

4

रेटिना , 70 59 बाइट्स

.
$.'$* $_$.`$* ¶
(?=((....))+)(?<-1>.)+(.*?)(?<-2>.)+¶
$3¶

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


मुझे लगता है कि मैं पहले 59 था। अब विवरण खुदाई करने के लिए समय नहीं है, लेकिन अनिवार्य रूप से पहले चरण में मैं बस के साथ इनपुट गद्देदार n/2रिक्त स्थान छोड़ दिया और सही (कुछ तरह का उपयोग कर (..)+.-> $#1$* $&$#1$*पीछे अंतरिक्ष के साथ) और फिर सिर्फ एक किया था !&`...जहां ...मैचों nबिल्कुल nअक्षर।
मार्टिन एंडर

आपका दृष्टिकोण कम से कम 63 तक छोटा हो सकता है: tio.run/##K0otycxL/…
मार्टिन

@MartinEnder धन्यवाद, और मैं एक और 4 बाइट्स निकाल चुका हूँ!
नील

क्या आपको दूसरे की आवश्यकता है $*sp?
कैलक्यूलेटरफ्लेन

@ कैलाकुलरफलाइन हाँ, मुझे सभी पंक्तियों की लंबाई समान होने की आवश्यकता है, इसलिए मैं इसे 4 से विभाजित कर सकता हूं
नील

3

जावा 8, 120 103 बाइट्स

s->{int l=s.length(),i=l/2;for(;i-->0;s=" "+s+" ");for(;++i<l;System.out.println(s.substring(i,l+i)));}

-17 बाइट्स की बदौलत @ OlivierGrégoire

स्पष्टीकरण:

इसे यहाँ आज़माएँ।

s->{                      // Method with String parameter and no return-type
  int l=s.length(),       //  Length of the input-String
      i=l/2;              //  Temp index-integer (starting at halve the length floored)
  for(;i-->0;             //  Loop (1) from `l/2` to 0 (exclusive)
    s=" "+s+" "           //   Add spaces before and after the input-String
  );                      //  End of loop (1)
                          //  (If the input was "World", it is now "  World  ")
  for(;++i<l;             //  Loop (2) from 0 to `l` (exclusive)
    System.out.println(   //   Print:
      s.substring(i,      //    Substring of the modified input from `i`
                    l+i)  //    to `l+i` (exclusive)
    )                     //   End of print
  );                      //  End of loop (2)
}                         // End of method

i=l/2+1और i-->1और for(;i<lएक बाइट सहेजें।
ओलिवियर ग्रेगोइरे

1
और ... पूरी तरह से गोल्फ: s->{int l=s.length(),i=l/2;while(i-->0)s=" "+s+" ";while(++i<l)System.out.println(s.substring(i,l+i));}(103 बाइट्स)। एकमात्र महत्वपूर्ण परिवर्तन यह है कि रिक्त स्थान के साथ स्ट्रिंग "फ्लाई पर" के बजाय एक बार और सभी के लिए उत्पन्न होता है (और निश्चित रूप से वापसी के बजाय प्रिंट)।
ओलिवियर ग्रेजायर

3

हास्केल, 64 62 बाइट्स

f s|l<-length s=take l$take l<$>scanr(:)""(([2,4..l]>>" ")++s)

इसे ऑनलाइन आज़माएं! यह काम किस प्रकार करता है:

l<-length s               -- let l be the length of the input string

      ([2,4..l]>>" ")     -- take l/2 spaces and
                     ++s  -- append s
    scanr(:)""            -- make a list of the inits of the above string, e.g.
                          -- "  world" -> ["  world"," world","world","orld"...]
  take l <$>              -- take the first l chars of each string
take l                    -- and the first l strings

3

एसडब्ल्यूआई प्रोलॉग, 234 बाइट्स

h(_,0,_,_,[]).
h(T,N,S,L,[H|U]):-sub_string(T,S,L,_,H),M is N-1,A is S+1,h(T,M,A,L,U).
s(T,R):-string_length(T,L),findall('_',between(1,L,_),A),string_chars(B,A),
                   string_concat(B,T,C),string_concat(C,B,D),S is L-((L-1)/2),h(D,L,S,L,R).

शायद यहाँ ऑनलाइन प्रयास करें: http://swish.swi-prolog.org/p/hEKigfEl.pl

एनबी।

  1. आखिरी पंक्ति एक लंबी लाइन है, मैंने इस उत्तर में क्षैतिज स्क्रॉलबार से बचने के लिए यहां एक लाइनब्रेक और रिक्त स्थान जोड़ा है।
  2. इस सवाल में पैडिंग के लिए स्थान शामिल हैं, लेकिन एचटीएमएल रेंडरिंग इंटरैक्शन के कारण स्विश ऑनलाइन उन्हें साफ-सुथरा नहीं दिखाता है, आपको ब्राउज़र देव टूल में स्रोत को देखने के लिए देखना होगा कि वे मौजूद हैं (वे हैं)। मैंने _यहां होने के लिए पैडिंग को बदल दिया है, क्योंकि यह इसे काम कर रहा है और बाइट की गिनती को प्रभावित नहीं करता है।

स्विश में चल रहे उदाहरण:

परीक्षण के मामलों

दृष्टिकोण, मूल रूप से पहली चीज जो मैं काम कर सकता था, और निस्संदेह एक कुशल प्रोलॉग उपयोगकर्ता इसे बहुत छोटा कर सकता था:

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

समझाया और टिप्पणी की गई कोड (नहीं चल सकता है), superacrostic()नीचे से पढ़ें , फिर helper()मुख्य निकाय, फिर helper()आधार मामला:

% helper function recursive base case, 
% matches when counter is 0, other input has any values, and empty list 'output'.
helper(_,0,_,_,[]). 



% helper function recursively generates substrings
% matching a padded input Text, a line Counter
% a substring starting Offset, a line Length,
% and an output list with a Head and a Tail
helper(Text, Counter, Offset, LineLength, [Head|Tail]):-

    sub_string(Text, Offset, LineLength, _, Head),    % The list Head matches
                                                      % a substring of Text starting 
                                                      % from Offset, of LineLength chars 
                                                      % and

    NextCounter is Counter-1,                         % decrement the Counter

    NextOffset is Offset+1,                           % increment the offset

    helper(Text, NextCounter, NextOffset, LineLength, Tail).  % Recurse for list Tail



% Result is a superacrostic for an input string Text, if
superacrostic(Text, Result):-
    string_length(Text, Length),                   % Length is length of input, 
                                                   % Text = 'ABXCD', Length = 5
                                                   % and

    findall('_',between(1,Length,_),PaddingList),  % PaddingList is a list of padding
                                                   % chars Length items long, 
                                                   % ['_', '_', '_', '_', '_']
                                                   % and

    string_chars(PaddingString, PaddingChars),     % PaddingString is the string from 
                                                   % joining up that list of chars
                                                   % '_____'
                                                   % and

    string_concat(PaddingString, Text, Temp),      % Temp is Text input with a
                                                   % padding prefix
                                                   % Temp = '_____ABXCD'
                                                   % and

    string_concat(Temp, PaddingString, PaddedText), % PaddedText is Temp with 
                                                    % a padded suffix
                                                    % Temp = '_____ABXCD_____'
                                                    % and


    S is Length - ((Length - 1) / 2),              % Starting offset S for the substring
                                                   % is just past the padding,
                                                   % then half the input length back
                                                   % '_____ABXCD_____'
                                                   %     |
                                                   % to start the first line,
                                                   % and


    helper(PaddedText, Length, S, Length, Result). % Result is the list generated from 
                                                   % the helper function, 

    % to recurse Length times for that many output rows, S starting offset, 
    % Length linelength, and Result 'output'.


2

जावास्क्रिप्ट (ईएस 6), 75 बाइट्स

f=(s,k=1,l=s.length)=>k>l?'':(' '.repeat(l)+s).substr(l/2+k,l)+`
`+f(s,k+1)

console.log(f("World"))


72 बाइट्स । या 70 बाइट्स यदि आप ईएस 8 के साथ जाना चाहते हैं, तो जैसे मैंने किया।
झबरा

2

एपीएल (डायलॉग यूनिकोड) , 10 चार्ट = 22 बाइट्स

{⊢⌺(≢⍵)⊢⍵}

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

{} अनाम फ़ंक्शन जहां तर्क argument द्वारा दर्शाया गया है

 कवर क्षेत्र जब प्रदान करते हैं

⌺(... ) आकार के एक स्टैंसिल फिसलने

   की लंबाई

   बहस

 पर

 बहस

जिस तरह से यह काम करता है वह प्रत्येक वर्ण को स्ट्रिंग के बीच में इनपुट के समान लंबाई के साथ देता है, आवश्यकतानुसार बाएं या दाएं पैडिंग। उदाहरण लीजिएABXCD :

स्ट्रिंग में पाँच वर्ण हैं, इसलिए स्टैंसिल में एक "ओपनिंग" होगा जो पाँच वर्णों वाला होगा।

┌──↓──┐     मध्य मार्कर के साथ स्टेंसिल उद्घाटन
│ ABX│CD   आज्ञा देना Aबीच में होना
 │ ABXC│D   तो B
  │ABXCD|   आदि
  A|BXCD | 
  AB|XCD  |
    └──↑──┘ अंतिम स्टेंसिल स्थिति



2

जावास्क्रिप्ट (ईएस 8), 66 63 62 बाइट्स

एक सरणी देता है।

s=>[...s].map((_,x)=>s.padStart(l*1.5).substr(x,l),l=s.length)

कोशिश करो

o.innerText=(f=
s=>[...s].map((_,x)=>s.padStart(l*1.5).substr(x,l),l=s.length)
)(i.value="Pneumonoultramicroscopicsilicovolcanoconiosis").join`\n`;oninput=_=>o.innerText=f(i.value).join`\n`
<input id=i><pre id=o>


व्याख्या

s=>

अनाम फ़ंक्शन स्ट्रिंग को पैरामीटर के माध्यम से एक तर्क के रूप में ले रहा है s

[...s]

स्ट्रिंग को अलग-अलग वर्णों की एक सरणी में विभाजित करें।

l=s.length

स्ट्रिंग की लंबाई प्राप्त करें और इसे वेरिएबल में असाइन करें l

.map((_,x)=>                                        )

सरणी पर नक्शा, प्रत्येक तत्व को एक फ़ंक्शन के माध्यम से पारित करना, जहां xवर्तमान तत्व का सूचकांक है।

s.padStart(l*1.5)

प्रत्येक तत्व के लिए, मूल स्ट्रिंग को तब तक रिक्त स्थान के साथ लौटाएं जब तक कि यह लंबाई का 1.5 गुना न हो जाए।

.substr(x,l)

lवर्तमान तत्व के सूचकांक से शुरू होने वाली लंबाई का विकल्प प्राप्त करें ।


2

वी , 14 , 11 बाइट्स

òlÙxHÄ$x>>ê

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

3 बाइट्स ने @nmjmcman को धन्यवाद दिया!

Hexdump:

00000000: f26c d978 48c4 2478 3e3e ea              .l.xH.$x>>.

मूल दृष्टिकोण (18 बाइट्स):

ø..
Duu@"ñLÙxHÄ$x>

स्पष्टीकरण:

ò           " Recursively:
 l          "   Move one char to the right (this will break the loop if we move too far
  Ù         "   Duplicate this line down
   x        "   Delete the first character on this line
    H       "   Move to the first line
     Ä      "   Duplicate this line up
      $     "   Move to the end of this line
       x    "   And delete a character
        >>  "   Put one space at the beginning of this line
          ê "   And move to this column on the last line
            " (implicit) ò, end the loop.

कुछ बाइट्स सहेजें: इसे ऑनलाइन आज़माएं!
nmjcman101

@ nmjcman101 आह, यह प्रतिभा है! मैं पूरी तरह से भूल गया ê। धन्यवाद :)
DJMcMayhem

2

पॉवरशेल कोर , 68 बाइट्स

0..($L=($a="$args").Length-1)|%{-join(' '*($L/2)+$a)[($_..($_+$L))]}

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

अघोषित स्पष्टीकरण

# Input string ABXCD
# -> indexes  0,1,2,3,4  string indexing and num of output lines.
# -> Pad with half-len of spaces __ABXCD.
# -> sliding window array of chars:
# __ABXCD
# |    |       0..4
#  |    |      1..5
#   |    |     2..6
#    |    |    3..7   (selecting indexes past the end returns $nulls, no error)
#     |    |   4..8

# joining those chars into a line


$Text = "$args"                            # script args array to string.
$L    = $Text.Length - 1                   # useful number

$Offsets = 0..$L                           # range array 0,1,2,3,.. to last offset

$Offsets | ForEach-Object {                # Offsets doubles as number of output lines

    $LinePadding = ' ' * ($L / 2)          # lead padding string __
    $PaddedText  = $LinePadding + $Text    # -> __ABXCD

    $Chars = $_..($_+$L)                   # windows 0..4, then 1..5, then 2..6, etc.
    $Line  = $PaddedText[$Chars]           #_,_,A,B,X then _,A,B,X,C then A,B,X,C,D etc.

    -join $Line                            # __ABX  then _ABXC then ABXCD etc.

}

1
देखभाल में शामिल होने के लिए ungolf [($_..($_+$L))]?
मूल

@ छोटा उत्तर, (ज्वाइन के साथ नहीं जाता है, यह -join ($Padding + $Text)[0,1,2,3,4]आउटपुट लाइन के लिए गद्देदार स्ट्रिंग से कई वर्णों का चयन करने के लिए कर रहा है, और ऐसा करने के लिए उन्हें एक छोटे तरीके से जोड़ने के लिए एक स्ट्रिंग में शामिल करना है .SubString()। और यह इन-प्लेसिंग और इन-प्लेस वर्णों की श्रेणी उत्पन्न कर रहा है। पूर्ण ungolf स्पष्टीकरण मेरे जवाब में जोड़ा गया।
TessellatingHeckler

2

जाप , 19 17 14 बाइट्स

सहेजे गए 5 बाइट्स @ETHproductions और @Shaggy की बदौलत

¬£iSp½*Ul¹tYUl

इसे ऑनलाइन टेस्ट करें! -Rध्वज को नई पंक्ति (दृश्यता उद्देश्यों) में शामिल होने के लिए जोड़ा गया

व्याख्या

¬£iSp½*Ul¹tYUl
                U = Implicit input
¬               Split the input into an array of chars
 £              Map; At each char:
  i               Insert:
   S                Space " "
    p               repeated(
     ½*Ul           .5 * U.length times 
         ¹          )
          t        Substring(
           Y         Index,
            Ul       U.length) 

1
उत्पन्न करने के लिए बहुत कम रास्ता होना चाहिए Sp½*Ul, लेकिन मुझे नहीं लगता कि एक एटीएम है ... BTW, आप आमतौर sXX+Yपर tXY(। s == .slice, t == .substr) में बदल सकते हैं
ETHproductions

@ETHproductions ओह हाँ, धन्यवाद!
ओलिवर


या, देखने के रूप में एक सरणी की अनुमति है, 14 बाइट्स
झबरा



1

QBIC , 32 बाइट्स

_L;|A=space$(a'\`2)+A[a|?_sA,b,a    

यार, मुझे जोड़ने का समय हो गया है space$ लिए QBIC में ...

व्याख्या

  ;             Read a cmd line parameter as A$
_L |            And take its length as 'a'
A=space$        Set A$ to a number of spaces
(a'\`2)           equal to its own length halved
+A                prepended to itself
[a|             FOR b= 1 to the length of A$
?_sA,b,a        Print a substring of our space-padded A$, starting at the b'th character, running for a chars

नमूना चला

Command line: acknowledgement
       acknowle
      acknowled
     acknowledg
    acknowledge
   acknowledgem
  acknowledgeme
 acknowledgemen
acknowledgement
cknowledgement
knowledgement
nowledgement
owledgement
wledgement
ledgement
edgement

1

मैथेमेटिका, 88 बाइट्स

T=Table;Column@Reverse@T[T[" ",i]<>StringDrop[s=#,-i],{i,d=-⌊StringLength@s/2⌋,-d}]&

1

हास्केल , 86 70 बाइट्स

यह (अभी भी) बहुत लंबा रास्ता है, लेकिन मुझे याद दिलाने के लिए @bartvelle का धन्यवाद कि तार की एक सूची तैयार करना भी स्वीकार्य है!

f s|m<-div(length s)2=take(2*m+1).(`drop`((*>)s" "++s))<$>[m+1..3*m+1]

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


मैं केवल 82 तक ही पहुँच सका: इसे ऑनलाइन आज़माएँ!
बर्तवेल्ले

@bartvelle यह सही नहीं लगता। आपका दाहिना भाग कटा हुआ नहीं है।
Adám

हाँ, मैंने एक बग पेश किया! आप अपने कॉनैट को गिराकर थोड़ा लाभ प्राप्त कर सकते हैं: इसे ऑनलाइन आज़माएं!
बर्तवेल्ले

और चॉपिंग के साथ यह 84 है, जो आपके दृष्टिकोण को बेहतर बनाता है! इसे ऑनलाइन आज़माएं!
बर्तवेल्ले

और आप बहुत अधिक बचा सकते हैं, क्योंकि आपको एक भी स्ट्रिंग वापस करने की आवश्यकता नहीं है, तार की सूची भी ठीक है!
बर्तवेल्ले


1

पॉवरशेल , 133 119 बाइट्स

$a="$args";$L=$a.Length;$m=($L+1)/2;$s=" "*($m-1)+$a+" "*($m-1);for($h=0;$h-lt$L;$h++){$r="";0..$L|%{$r+=$s[$_+$h]};$r}

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

Ungolfed

$a="$args"
$L=$a.Length                        # the length of the input
$m=($L + 1) / 2                     # the midpoint of the input
$s=" " * ($m-1) + $a + " " * ($m-1) # create a string using the input and padded on both sides with spaces

for($h=0;$h -lt $L;$h++) {          # the height, matching the length of the input
    $r=""                           # init/reset the output string

    0..$L | % {                     # number range to represent each character in the string
        $r+=$s[$_+$h]               # append the output string with the next character
    }

    $r                              # write the output
}

1
अच्छा जवाब! साइट पर आपका स्वागत है। :)
DJMcMayhem

1

अजगर २ ,76 74 73 बाइट्स

-1 धन्यवाद @FelipeNardiBatista

बेशक, अन्य पायथन उत्तर जितना छोटा नहीं है, लेकिन यह पूरी तरह से अलग तरीके की कोशिश करने के लायक है:

n=input();x=len(n)
for i in range(x):print((2*x-~i)*' '+n)[x+x/2:2*x+x/2]

इसे ऑनलाइन आज़माएं!(74 बाइट संस्करण के साथ)

यह पहले पूर्ण स्ट्रिंग उत्पन्न करता है, और फिर इसे स्क्वायर फिट करने के लिए स्लाइस करता है।


व्याख्या

एन = इनपुट (); - इनपुट लेता है और इसे वेरिएबल n पर असाइन करता है
          x = len (n) - एक चर x को इनपुट की लंबाई प्रदान करता है
i for रेंज (x) में: - यह 0 पर है ... x, एक वेरिएबल i के साथ है
                   प्रिंट - परिणाम को आउटपुट करता है
                         ((2 * xi-1) * '' + n) - "डायमंड" स्ट्रिंग बनाता है
                                          [x + x / 2: 2 * x + x / 2] - बॉक्स को फिट करने के लिए स्ट्रिंग को क्रॉप करता है

(2*x+~i)एक बाइट बचाने के लिए
फेलिप नारदी बतिस्ता

@FelipeNardiBatista धन्यवाद।

1

जे , 19 बाइट्स

|.!.' '"{~2%~#\-#\.

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

व्याख्या

|.!.' '"{~2%~#\-#\.  Input: string S
             #\      Length of each prefix of S, [1, 2, ..., len(S)]
                #\.  Length of each suffix of S, [len(s), ..., 2, 1]
               -     Subtract elementwise
          2%~        Divide by 2
                     We now have a range [(1-len(S))/2, ..., -1, 0, 1, ..., (len(S)-1)/2]
       "{~           Use each value to operate on S
|.!.' '                Perform a shift while replacing characters with ' '

''प्रतिस्थापन के साथ काम करता है ।
FrownyFrog

0

सी # (.NET कोर) , 101 बाइट्स

(a)=>{int L=a.Length,l=L/2;for(;l-->0;)a=" "+a+" ";for(;++l<L;)Console.WriteLine(a.Substring(l,L));};

मूल रूप से @ केविनक्रूजसेन का जवाब। 2 बाइट्स बचाता है क्योंकि string.Length() और दूसरे 2 बाइट्स की आवश्यकता नहीं होती है क्योंकि एंड का दूसरा तर्क string.Substring()इंडेक्स के बजाय लंबाई है, लेकिन फिर 2 बाइट्स खो देता है क्योंकि Console.WriteLine()लंबा है। मेरे पास अधिक भोली कार्यान्वयन था, लेकिन यह लगभग दो बार था ...


0

एक्सेल VBA, 68 बाइट्स

golfed

अनाम VBE तत्काल विंडो फ़ंक्शन जो VBE तत्काल विंडो में सेल [A1]और आउटपुट से इनपुट लेता है

l=[Len(A1)]:For i=Int(-l/2)+2To l/2+1:?Mid(Space(l-i)&[A1],l,l):Next

Ungolfed

Sub C(ByVal s As String)
    Let l = Len(s)
    For i = Int(-l / 2) + 2 To l / 2 + 1 Step 1
        Debug.Print Mid(Space(l - i) & s, l, l)
    Next i
End Sub

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