Wc coreutil को फिर से लागू करें


27

यह चुनौती इस पुरानी के समान है , लेकिन कल्पना के कुछ अस्पष्ट हिस्सों के साथ बाहर निकला है और कम सख्त I / O आवश्यकताएं हैं।


केवल मुद्रण योग्य ASCII और newlines से युक्त एक स्ट्रिंग के इनपुट को देखते हुए, इसके विभिन्न मैट्रिक्स (बाइट, वर्ड, लाइन काउंट) को आउटपुट करता है।

आपके द्वारा आउटपुट किए जाने वाले मीट्रिक इस प्रकार हैं:

  • बाइट की गिनती। चूंकि इनपुट स्ट्रिंग ASCII के भीतर रहती है, इसलिए यह वर्ण गणना भी है।

  • शब्द गणना। यह wcएक "शब्द की परिभाषा है:" गैर-व्हाट्सएप का कोई भी क्रम। उदाहरण के लिए, abc,def"ghi"एक "शब्द" है।

  • लाइन की गिनती। यह स्व-व्याख्यात्मक है। इनपुट में हमेशा एक अनुगामी न्यूलाइन होगी, जिसका अर्थ है कि लाइन काउंट "न्यूलाइन काउंट" का पर्याय है। एक एकल अनुगामी न्यूलाइन से अधिक कभी नहीं होगा।

आउटपुट को बिल्कुल डिफ़ॉल्ट wcआउटपुट (फ़ाइल नाम को छोड़कर) को दोहराया जाना चाहिए :

llama@llama:~$ cat /dev/urandom | tr -cd 'A-Za-z \n' | head -90 > example.txt
llama@llama:~$ wc example.txt
  90  165 5501 example.txt

ध्यान दें कि लाइन काउंट पहले आता है, फिर वर्ड काउंट, और अंत में बाइट काउंट। इसके अलावा, प्रत्येक गणना को रिक्त स्थान के साथ छोड़ दिया जाना चाहिए जैसे कि वे सभी समान चौड़ाई वाले हों। उपरोक्त उदाहरण में, 55014 अंकों के साथ "सबसे लंबी" संख्या है, इसलिए 165एक स्थान और 90दो के साथ गद्देदार है । अंत में, संख्याओं को प्रत्येक संख्या के बीच के स्थान के साथ एकल स्ट्रिंग में शामिल किया जाना चाहिए।

चूंकि यह , बाइट्स में सबसे छोटा कोड जीत जाएगा।

(ओह, और वैसे भी ... आप wcअपने जवाब में कमांड का उपयोग नहीं कर सकते । उस स्थिति में जो पहले से स्पष्ट नहीं था।)

परीक्षण के मामले ( \nएक नई रेखा का प्रतिनिधित्व करते हैं; आपको वैकल्पिक रूप से एक अतिरिक्त अनुगामी नई पंक्ति की आवश्यकता हो सकती है):

"a b c d\n" -> "1 4 8"
"a b c d e f\n" -> " 1  6 12"
"  a b c d e f  \n" -> " 1  6 16"
"a\nb\nc\nd\n" -> "4 4 8"
"a\n\n\nb\nc\nd\n" -> " 6  4 10"
"abc123{}[]()...\n" -> " 1  1 16
"\n" -> "1 0 1"
"   \n" -> "1 0 4"
"\n\n\n\n\n" -> "5 0 5"
"\n\n\na\nb\n" -> "5 2 7"

2
मैं VTC को पुराने वाले के रूप में देख रहा हूँ क्योंकि यह एक बेहतर चुनौती है।
मेगो

क्या खाली इनपुट का समर्थन किया जाना चाहिए?
टन हास्पेल

मुझे ऐसा नहीं लगता, उन्होंने कहा कि सभी इनपुट \ n के साथ समाप्त होते हैं।
कैलकुलेटर

जवाबों:


8

पर्ल, 49 बाइट्स

के लिए +3 जोड़ा गया -an0

STDIN पर इनपुट या 1 या अधिक फ़ाइलनामों को तर्क के रूप में। ऐसे दोड़ोperl -an0 wc.pl

wc.pl:

/\z/g;pos=~//;printf"%@+d %@+d $`
",y/
//,~~@F

स्पष्टीकरण:

-n0      slurps the whole input into $_ and says we will do our own printing
-a       tells perl to split the input on whitespace into array @F
/\z/g    Matches the absolute end of the input. g modifier so the position 
         is remembered in pos which will now contain the input length
pos=~//  An empy regex repeats the last succesful match, so /\z/ again.
         After that $` will contain the the number of input characters and
         the array @+ will contain the length of this number
printf   All preparation is complete, we can go print the result
"%@+d"   will become e.g. %6d if the number of characters is a number of
         length 6, so lines and words will get printed right aligned 
         in a field of length 6.
$`       $` we can directly interpolate since it won't contain a %
y/\n//   Count the number of newlines in $_
~~@F     The array of words @F in scalar context gives the number of words

7

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

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

संपादित करें: डेनिस द्वारा प्रिंट अनुकूलन के कारण 23 बाइट्स सहेजे गए।

def d(b):c=len(b);a='%%%us'%len(`c`);print a%b.count('\n'),a%len(b.split()),c

मिनिफ़ायर से पहले, यह इस तरह दिखता है:

def wc(text) :
    size = len(text);
    numfmt = '%%%us' % len(`size`);
    print numfmt % text.count('\n'), numfmt % len(text.split()), size

7

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

jdm.[;l`lQ`ld[@bQcQ)Q

परीक्षण सूट

Pyth के पास कुछ बहुत अच्छे बिल्ट-इन हैं। हम [स्ट्रिंग में नईलाइन्स की सूची ( ), स्ट्रिंग @bQमें शब्द ( cQ)) और स्वयं स्ट्रिंग ( ) बनाकर शुरू करते हैं Q। फिर, हम .[प्रत्येक स्ट्रिंग की लंबाई ( ld) के साथ रिक्त स्थान ( ;इस संदर्भ में) वर्णों की संख्या की लंबाई तक ( l`lQ) करते हैं। अंत में, रिक्त स्थान पर शामिल हों ( jd)।


6

POSIX awk, 79 75 67 65 बाइट्स

{w+=NF;c+=length+1}END{d=length(c)"d %";printf"%"d d"d\n",NR,w,c}

संपादित करें: 4 बाइट सहेजे थे जब POSIX एक नंगे अनुमति देता है length, मंगलाचरण हिस्सा छूट से 7 बाइट्स बचा लिया, और जोड़ने के लिए दरवाज़े के टिप करने के लिए दो बाइट्स धन्यवाद बचाया d %करने के लिए d

यह मूल रूप से GNU awk के लिए था, लेकिन सबसे अच्छा मैं बता सकता हूं, यह केवल POSIX awk कार्यक्षमता का उपयोग करता है।

बेहतर स्वरूपित:

gawk '{
  w += NF
  c += length($0) + 1  # length($0) misses the newline
}
END {
  d = length(c) # GNU awk's length returns the length of string representation of number
  printf "%"d"d %"d"d %d\n", NR, w, c
}'

@Doorknob ठीक है, इसके लिए धन्यवाद। लगता है कि आपने बातचीत को देखा? इसके अलावा, उस प्रश्न को फेक-प्रस्तावित से लेकर फेक तक स्नातक होना चाहिए ।
मुरु

1
ओह, मैंने आपको चैट में नहीं देखा; आपका जवाब सिर्फ मेरे इनबॉक्स में पॉप अप किया गया था: PI वह था जिसने उस सवाल में [faq- प्रस्तावित] को जोड़ा था, इसलिए हो सकता है कि मैं इसे [faq] में अपग्रेड करने से पहले मॉड रूम में जांच करूं।
दरवाज़े

1
स्थापना dकरने के लिए length(c)"d %"आप को बदलने के लिए अनुमति चाहिए printfकरने के लिए "%"d d"d\n"है, जो दो बाइट्स की बचत होती है।
दरवाज़े

1
@Doorknob वास्तव में, धन्यवाद! लगता है कि यह विदेशी नहीं है , लेकिन सांसारिक जो बाइट्स बचाता है।
मूरू

6

गंभीरता से , 39 बाइट्स

"
 "╩╜l;$l╝@╜sl'
╜ck`#╛#"{:>%d}"%f`M' j

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

स्पष्टीकरण (नई लाइनों के साथ बदल दिया जाता है \n):

"\n "╩╜l;$l╝@╜sl'\n╜ck`#╛#"{:>%d}"%f`M' j
"\n "                                      push a string containing a newline and a space
     ╩                                     push input to register 0 (we'll call it s)
      ╜l;                                  push two copies of len(s) (byte count)
         $l╝                               push len(str(len(s))) to register 1
                                            (this will serve as the field width in the output)
            @╜sl                           push word count by getting the length of the list formed by
                                            splitting s on spaces and newlines
                '\n╜c                      count newlines in input
                     k                     push stack to list
                      `#╛#"{:>%d}"%f`M     map:
                       #                     listify
                        ╛#                   push reg 1 (field width), listify
                          "{:>%d}"           push that string
                                  %          do old-style string formatting for field width
                                   f         do new-style string formatting to pad the field appropriately
                                      ' j  join on spaces

मैं इस भाषा के लिए कोई दस्तावेज नहीं दे सकता, क्या आप एक लिंक प्रदान कर सकते हैं?
जॉनएई

2
@ जोहानिये, github.com/Mego/Seriously
awesoon

3

AppleScript, 253 बाइट्स

यह मानता है कि AppleScript के टेक्स्ट आइटम सीमांकक अंतरिक्ष में सेट हैं (यदि मुझे उस धारणा को बल देने के लिए सामान को गिनने की आवश्यकता है, तो मैं इसे जोड़ दूंगा)।

set w to(display dialog""default answer"")'s text returned
set x to b(w)
set y to w's text item's number
set z to w's paragraph's number
a(x,z)&z&a(x,y)&y&" "&x
on a(x,n)
set o to" "
repeat b(x)-b(n)
set o to o&" "
end
o
end
on b(n)
count(n as text)
end

3

सीजेएम, 31 26 बाइट्स

q_)/_S*S%@_]:,:s),f{Se[}S*

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

यह काम किस प्रकार करता है

q_                         e# Read all input from STDIN and push two copies.
  )                        e# Pop the last character (linefeed) of the second copy.
   /                       e# Split the remaining string at linefeeds.
    _                      e# Push a copy.
     S*                    e# Join the copy, separating by spaces.
       S%                  e# Split at runs of spaces.
         @_                e# Rotate the original input on top and push a copy.
           ]               e# Wrap all four items in an array.
            :,             e# Get the length of each item.
              :s           e# Cast the lengths (integers) to strings.
                )          e# Pop the last length (byte count).
                 ,         e# Get the number of digits.
                  f{Se[}   e# Left-pad all three length with spaces to that length.
                        S* e# Join, separating by spaces.

3

जूलिया, 112 81 बाइट्स

f(s,n=endof,l="$(n(s))",g=r->lpad(n(split(s,r))-1,n(l)))=g(r"\n")" "g(r"\S+")" "l

यह एक फ़ंक्शन है जो एक स्ट्रिंग को स्वीकार करता है और एक स्ट्रिंग लौटाता है।

हम फ़ंक्शन तर्कों के रूप में निम्नलिखित को सहेजते हैं:

  • n = endof फ़ंक्शन, जिसे इंडेक्सेबल संग्रह का अंतिम इंडेक्स मिलता है (इस मामले में स्ट्रिंग की लंबाई है)
  • l = "$(n(s))प्रक्षेप की मदद से इनपुट की लंबाई स्ट्रिंग में परिवर्तित हो जाती है
  • एक लैम्ब्डा फ़ंक्शन gजो एक नियमित अभिव्यक्ति को स्वीकार करता है और लंबाई को मैच करने के लिए रिक्त स्थान के साथ गद्देदार छोड़ दिया जाता है, उस रेगेक्स पर इनपुट विभाजन का 1 - लंबाई लौटाता है l

हमें उपयोग करने वाली रेखाओं g(r"\n")की संख्या और उपयोग करने वाले शब्दों की संख्या मिलती है g(r"\S+"), फिर हम lरिक्त स्थान द्वारा सीमांकित के साथ जुड़ते हैं ।

डेनिस की बदौलत 31 बाइट बच गईं!


2

MATL, 38 बाइट्स

'\n'32cZtttnGnw-wPZvPYbnqbnvvV!3Z"vX:!

आप इसे ऑनलाइन आज़मा सकते हैं ! यह इतना लंबा नहीं होना चाहिए ...

गणना के लिए स्पष्टीकरण,

'\n'32cZt  %// Takes implicit input and replaces any \n with a space
tt         %// Duplicate that string twice
nGnw-w     %// Length of the string with \n's minus length with spaces to give number of \n's
PZvPYbnq   %// Take string with spaces, flip it, remove leading spaces, flip it again,
           %// split on spaces, find length and decrement for number of words
bn         %// get length of string with spaces, the number of characters

अंतिम भाग आउटपुट स्वरूपण करता है

vvV!       %// concatenate the 3 numbers to a column vector, convert to string and transpose
3Z"v       %// make string '   ' and concatenate on the bottom of previous string
X:!        %// linearise and transpose to get correct output (impicitly printed)

अच्छी तरह से किया! हो सकता है कि यह ऑनलाइन लिंक आज़माएं "डिबग" ध्वज को हटा दें ?
लुइस मेन्डो

आह उफ़! सर उठाने के लिए धन्यवाद!
डेविड

मुझे लगता है कि आप की जगह ले सकता !3Z"vX:!से Z{Zc( cellstrके बाद strjoin)
लुइस Mendo

1

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

s=>[/\n\/g,/\S+/g,/[^]/g].map(r=>l=(s.match(r)||[]).length).map(n=>(' '.repeat(99)+n).slice(-`${l}`.length)).join` `

किसी इनपुट की आवश्यकता नहीं है। स्वरूपण दर्दनाक था। अगर गद्दी की मात्रा पर ऊपरी सीमा होती तो मैं (' '.repeat(99)+n)कुछ कम कर सकता था जैसे कि ` ${n}`


मुझे लगता है कि आप की जगह ले सकता /[^]/gके साथ /./gकरने के लिए सेव दो बाइट्स
पैट्रिक रॉबर्ट्स

@PatrickRoberts नहीं, यह नई सीमा को छोड़ देता है, इसलिए मेरी गिनती बंद हो जाएगी।
नील

आह, उस पर पहले कभी गौर नहीं किया।
पैट्रिक रॉबर्ट्स

1

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

param($a)$c="$((($l=($a-split"`n").Count-1),($w=($a-split"\S+").Count-1),($b=$a.length)|sort)[-1])".Length;
"{0,$c} {1,$c} {2,$c}"-f$l,$w,$b

(स्पष्टता के लिए नई लाइन छोड़ी गई: डी)

पहली पंक्ति इनपुट लेती है $a, और फिर अगला भाग सभी एक बयान होता है। हम कुछ स्ट्रिंग के$c बराबर सेट कर रहे हैं । इससे हमारी अपेक्षित पैडिंग बन जाएगी। स्ट्रिंग के अंदर एक तत्काल कोड ब्लॉक होता है , जिससे कि स्ट्रिंग में मूल्यांकन करने से पहले उस कोड को निष्पादित किया जाएगा। .length$(...)

कोड ब्लॉक में, हम |sortकमांड के माध्यम से तीन आइटम भेज रहे हैं , और फिर सबसे बड़ा एक ले रहे हैं (...)[-1]। यह वह जगह है जहाँ हम स्तंभों को सही चौड़ाई पर ले जाना सुनिश्चित कर रहे हैं। तीन आइटम $lलाइन की गिनती है, जहां हम -splitनई सुर्खियों में हैं, $wशब्द गणना, जहां हम -splitव्हाट्सएप पर हैं, और $bलंबाई।

दूसरी पंक्ति -fऑपरेटर (जो एक छद्म शॉर्टहैंड है String.Format()) का उपयोग करके हमारा आउटपुट है । यह विस्तारित चर में तार डालने का एक और तरीका है। यहां, हम कह रहे हैं कि हम चाहते हैं कि आउटपुट का लेफ्ट बाईं ओर पैडेड हो ताकि प्रत्येक कॉलम $cचौड़ा हो। पैडिंग रिक्त स्थान के माध्यम से किया जाता है। 0, 1, और 2के अनुरूप $l, $wहै, और $bइसलिए लाइन गिनती, शब्द गणना, और बाइट गिनती उचित रूप से गद्देदार और आउटपुट हैं कि, प्रारूप ऑपरेटर के लिए तर्क हैं।

ध्यान दें कि इसके लिए या तो पहले से विस्तारित न्यूलाइन्स की स्ट्रिंग की आवश्यकता होती है (जैसे, Get-Contentकिसी टेक्स्ट फ़ाइल या किसी चीज़ पर करना, और फिर या तो उसे पाइप करना या सहेजना, फिर उस कोड को उस इनपुट पर कॉल करना), या PowerShell का उपयोग करें- बैकटिक्स के साथ स्टाइल वाले एस्केप कैरेक्टर ( `nइसके बजाय अर्थ \n)।

उदाहरण

PS C:\Tools\Scripts\golfing> .\reimplement-wc.ps1 "This line`nis broken`ninto three lines.`n"
 3  7 38


0

रूबी, 108 बाइट्स

f=->s{a=[s.count($/),s.split(/\S+/).size-1,s.size].map(&:to_s)
a.map{|b|" "*(a.map(&:size).max-b.size)+b}*" "}

0

पर्ल, 71 62 61 बाइट्स

के लिए +1 शामिल है -n

$;=length($b+=y///c);$w+=split$"}{printf"%$;d %$;d $b",$.,$w

टिप्पणी की:

while (<>) {                         # implicit because of -n
    $; = length(                     # printf formatting: width
       $b += y///c                   # count characters
    );
    $w += split $"                   # count words
}{                                   # explicit: end while, begin END block
    printf "%$;d %$;d $b", $., $w    #  $. = $INPUT_LINE_NUMBER
}                                    # implicit because of -n
  • एक और बाइट बचाओ, @TonHospel के लिए फिर से धन्यवाद।
  • @ व्यापार के कुछ ट्रिक्स दिखाते हुए @TonHospel को 9 बाइट्स बचाएं!

व्यापार की कुछ तरकीबें: y///cछोटी लंबाई के रूप में उपयोग करें $_split$"स्केलर संदर्भ में शब्दों की संख्या देता है $_। विराम चिह्न का उपयोग करके जैसे आप के $;बजाय प्रारूप स्ट्रिंग में प्रक्षेप के बाद $Wडाल सकते हैं d। तो फिर तुम छोड़ सकते हैं dमें $Wऔर कोष्ठक छोड़ देते हैं। और -pकुछ भी हासिल नहीं हुआ -n, बस printfछपाई करने दो (स्वाद के लिए एक नई
पंक्ति

बहुत बढ़िया, मैं इसकी सराहना करता हूं!
केनी

एक गणना श्रृंखला $a=foo;$b=bar$aको आमतौर पर $b=bar($a=foo)एक बाइट की बचत के रूप में लिखा जा सकता है । करने के लिए यहाँ लागू $;और $b। आप परवाह नहीं है अगर $;हर बार पुनर्गणना की जाती है
टन इंजील

धन्यवाद! मैंने इस बात को नजरअंदाज कर दिया कि क्योंकि दो ब्लॉक हैं ...
केनी

0

लुआ, 74 66 बाइट्स

golfed:

t=arg[1]_,l=t:gsub('\n','')_,w=t:gsub('%S+','')print(l,w,t:len())

Ungolfed:

text = arg[1]
_,lines = text:gsub('\n','')
_,words = text:gsub('%S+','')
print(lines, words, text:len())

कमांड लाइन तर्कों के माध्यम से इनपुट प्राप्त करता है।

arg[1]बाइट्स को बचाने के लिए हम पहले तर्क ( ) का नाम बदल देते हैं । string.gsubप्रतिस्थापन की संख्या के साथ-साथ संशोधित स्ट्रिंग भी लौटाता है, इसलिए हम पहले '\n'(newlines) को गिनने के लिए उपयोग कर रहे हैं , फिर '%S+'(एक या अधिक गैर-व्हाट्सएप वर्णों के उदाहरण, जहां तक ​​संभव हो, यानी शब्द)। हम प्रतिस्थापन स्ट्रिंग के लिए कुछ भी उपयोग कर सकते हैं, इसलिए हम ''बाइट्स को बचाने के लिए खाली स्ट्रिंग ( ) का उपयोग करते हैं । तब हम केवल string.lenस्ट्रिंग की लंबाई, यानी बाइट की संख्या का पता लगाने के लिए उपयोग करते हैं। फिर, आखिरकार, हम यह सब छापते हैं।


मैं हालांकि लाइनों और शब्दों के मूल्यों के किसी भी बाएं गद्दी को नहीं देखता हूं
टन हास्पेल

0

65, रेटिना

^((\S+)|(¶)|.)*
$#3 $#2 $.0
+`(\b(.)+ )(?!.*\b(?<-2>.)+$)
a$1
a
<space>

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

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


0

हास्केल, 140 बाइट्स

import Text.Printf
w h=let{l=length;s=show.l;c=s h;m=s.words$h;n=s.lines$h;f=maximum$map l[c, m, n];p=printf"%*s"f}in p n++' ':p m++' ':p c

विस्तारित संस्करण और फ़ंक्शन नामों के साथ ungolfed संस्करण यहां है:

import Text.Printf

wc str =
  let charcount = show.length $ str
      wordcount = show.length.words $ str
      linecount = show.length.lines $ str
      fieldwidth = maximum $ map length [charcount, wordcount, linecount]
      printer = printf "%*s" fieldwidth
  in printer linecount ++ (' ' : printer wordcount ++ (' ' : printer charcount))

यह एक फ़ंक्शन है जो एक स्ट्रिंग को स्वीकार करता है और एक स्ट्रिंग लौटाता है। यह केवल दिए गए शब्दों (संख्याओं) को प्राप्त करने के लिए Preludeफ़ंक्शंस words(रिस्पांस lines) का उपयोग करता है, क्योंकि वे उसी परिभाषा का उपयोग करते प्रतीत होते हैं wc, फिर काउंट्स के बीच सबसे लंबा मान (स्ट्रिंग के रूप में) प्राप्त करता है और प्रिंटफ़ प्रारूप का उपयोग कर लेता है स्वरूपण के लिए इसके तर्कों के बीच की चौड़ाई।



0

05AB1E , 24 23 बाइट्स

¨¶¡¹… 
    S¡õK¹)€g§Zg>jJ¦

jवर्तमान में bugged है, इसलिए बिना 21 बाइट्स हो सकता था §और J..

इसे ऑनलाइन आज़माएं या सभी परीक्षण मामलों को सत्यापित करें

स्पष्टीकरण:

¨          # Remove the trailing newline of the (implicit) input
 ¶¡        # And split it on newlines
¹… 
    S¡     # Take the first input again, and split it on [" \n\t"]
      õK   # Then remove all empty string items
¹          # And take the first input again as is
)          # Wrap all three value of the stack to a single list
 g        # Take the length of each of the items
   §       # Cast the integers to strings (should have been implicit, but `j` is bugged)
    Z      # Take the max (always the last / amount of bytes) (without popping the list)
     g>    # Take the length + 1 of this max
       j   # Append leading spaces so all items or of this length
        J  # Join them together (should have been done by the `j` already, but it's bugged)
         ¦ # Remove the leading space (and output implicitly to STDOUT)

0

पिप -s , 25 बाइट्स

sX##a-#_._M[nNa`\S+`Na#a]

बहु-पंक्ति स्ट्रिंग को कमांड-लाइन तर्क के रूप में लेता है। इसे ऑनलाइन आज़माएं!

के लिए धन्यवाद डेनिस के CJam जवाब मुझे बनाने के लिए पता है कि सबसे लंबे समय तक नंबर हमेशा वर्ण को महत्वपूर्ण है।

व्याख्या

                           s is space; n is newline; a is 1st cmdline arg (implicit)
           [            ]  Construct a list of three elements:
            nNa             Number of newlines in a
               `\S+`Na      Regex search: number of runs of non-whitespace characters in a
                      #a    Length of a (i.e. number of characters in a)
          M                To each element of that list, map this function:
   #a                       Number of characters in a
  #                         Length of that number
     -#_                    Subtract length of each element
sX                          Construct a string of that many spaces
        ._                  Prepend it to the element
                           The resulting list is autoprinted, space-separated (-s flag)

यहां -rsस्टड से इनपुट लेने वाले झंडे के साथ 29-बाइट समाधान है :

[#g`\S+`NST:gY#g+1]MsX#y-#_._

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


0

पॉवरशेल, 123 115 बाइट्स

switch -r($args|% t*y){'\s'{$a=0}'\S'{$w+=!$a;$a=1}'(?s).'{$b++}'
'{$l++}}$c="$b".Length
"{0,$c} {1,$c} $b"-f$l,+$w

टेस्ट स्क्रिप्ट:

$f = {

switch -r($args|% t*y){    # evaluate all matched cases
    '\s'   {$a=0}          # any whitespace (newline not included)
    '\S'   {$w+=!$a;$a=1}  # any not-whitespace (newline not included)
    '(?s).'{$b++}          # any char (newline included!)
    '`n'   {$l++}          # new line char
}
$c="$b".Length
"{0,$c} {1,$c} $b"-f$l,+$w


}

@(
    , ("a b c d`n", "1 4 8")
    , ("a b c d e f`n", " 1  6 12")
    , ("  a b c d e f  `n", " 1  6 16")
    , ("a`nb`nc`nd`n", "4 4 8")
    , ("a`n`n`nb`nc`nd`n", " 6  4 10")
    , ("abc123{}[]()...`n", " 1  1 16")
    , ("`n", "1 0 1")
    , ("   `n", "1 0 4")
    , ("`n`n`n`n`n", "5 0 5")
    , ("`n`n`na`nb`n", "5 2 7")
) | % {
    $s,$e = $_
    $r = &$f $s
    "$($e-eq$r): $r"
}

आउटपुट:

True: 1 4 8
True:  1  6 12
True:  1  6 16
True: 4 4 8
True:  6  4 10
True:  1  1 16
True: 1 0 1
True: 1 0 4
True: 5 0 5
True: 5 2 7

स्पष्टीकरण:

  • $args|% t*y बंटवारे की कलगी तार में
  • switch -r($args|% t*y)सभी मिलान किए गए मामलों का मूल्यांकन करें
    • '\s' किसी भी व्हाट्सएप के लिए मामला
    • '\S' किसी भी गैर-व्हाट्सएप के लिए मामला
    • '(?s).' किसी भी मामले के लिए मामला (नईलाइन शामिल)
    • '\n' newline char के लिए मामला (newline खुद का प्रतिनिधित्व करता है)
  • $c="$b".Lengthबाइट्स संख्या की गणना करें। $ b हमेशा डिजाइन द्वारा अधिकतम ($ l, $ w, $ b) होता है
  • "{0,$c} {1,$c} $b"-f$l,+$wएक ही लंबाई के साथ प्रारूप संख्या। चर $ w को इंट में कनवर्ट करता है। इसे बिना शब्दों के तार की जरूरत है। अन्य चर प्रारूप 'के रूप में' है, क्योंकि 'इनपुट में हमेशा एक अनुगामी न्यूलाइन होगी' और $ l और $ b 0 नहीं हो सकते।
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.