सांता का निर्णय


29

सांता का निर्णय:

इस चुनौती में, आप सांता क्लॉज़ को यह तय करने में मदद करेंगे कि क्या उनकी सूची में कोई व्यक्ति शरारती या अच्छा है, और बाद में मिलेगा coalया toys

लेकिन दुर्भाग्य से, सांता असंगठित है, उसकी कुछ प्रविष्टियों में naughty, nice और nameफ़ील्ड गलत क्रम में हैं।

इनपुट

इनपुट निम्नलिखित में आएगा, विनिमेय प्रारूप:

  • व्यक्ति का नाम (केवल एक बृहदान्त्र नहीं हो सकता है a-zA-Z0-9)
  • यह शब्द naughtyसीधे-सीधे एक बृहदान्त्र और एक गैर-नकारात्मक पूर्णांक द्वारा पीछा किया जाता है, जो सांता ने आपको शरारती होने के लिए पकड़ा है
  • यह शब्द niceसीधे तौर पर एक बृहदान्त्र और एक गैर-नकारात्मक पूर्णांक द्वारा पीछा किया जाता है जो सांता आपके द्वारा अच्छा होने पर पकड़े गए समय का प्रतिनिधित्व करता है

उनमें से प्रत्येक के बीच सभी एक ही व्हाट्सएप (ASCII 32) के साथ अलग हो गए।

इसके अतिरिक्त, नाम के हिस्सों के बीच में कोई व्हाट्सएप नहीं होगा Santa Claus-> SantaClaus

बोनस:

  • (25%) : वह सांता क्लॉस है, इसलिए उसे दो बार सूची की जांच करने की आवश्यकता है , और सुनिश्चित करें कि कोई डुप्लिकेट नहीं हैं। (किस स्थिति में, यह उपयोगकर्ता को मिलने वाला पहला स्कोर प्राप्त करता है)

उदाहरण:

Quill naughty:4 nice:0
naughty:0 Doorknob nice:3
naughty:2 Quill nice:6
nice:3 balpha naughty:3
pops nice:4 naughty:2

आउटपुट:

आउटपुट में निम्न शामिल होना चाहिए:

निम्नलिखित व्यक्ति का नाम:

  • यदि इसमें और अधिक बिंदु हैं naughty, तो coal:
  • अगर वहाँ अधिक अंक हैं nice, तो toys
  • लेकिन अगर naughtyऔर niceबराबर हैं, तोneeds more data

    उदाहरण आउटपुट:

  • संगठन बोनस और डुप्लिकेट हटाने बोनस के साथ:

Quill coal
Doorknob toys
balpha needs more data
pops toys
  • बिना बोनस:

Quill coal
Doorknob toys
Quill toys
balpha needs more data
pops toys

सबसे कम बाइट गिनती जीत!


4
परीक्षण मामलों में एक टाइपो भी है। आपने हमारे शानदार मॉड डॉर्कनोब के नाम को याद किया: ^)
FryAmTheEggman

9
@FryAmTheEggman ಠ_ಠ
दरवाज़े

2
नहींं, शरारती या अच्छा नाम वैध हैं
क्विल

1
यह एक अच्छा विचार है ... मुझे लगता है कि अगली बार हमेशा रहा है ...
क्विल

1
"बाल्फा को अधिक डेटा की आवश्यकता है" जो सही के बारे में लगता है।
एडम डेविस

जवाबों:



5

जूलिया, 176 169 बाइट्स

s->for l=split(s,"\n") M(r)=parse(matchall(r,l)[1]);g=M(r"e:\K\d+");b=M(r"y:\K\d+");println(replace(l,r" *\w+:\d+ *","")," ",g>b?"toys":b>g?"coal":"needs more data")end

यह एक अनाम फ़ंक्शन है जो एक स्ट्रिंग को स्वीकार करता है और परिणाम को STDOUT में प्रिंट करता है। इसे कॉल करने के लिए, इसे एक नाम दें, उदा f=s->...

Ungolfed:

function santa(s::AbstractString)
    # Split the input on newlines and process each line separately
    for l in split(s, "\n")
        # Define a function to get the number from the result of a
        # regular expression match
        M(r) = parse(matchall(r, l)[1])

        # Goodness
        g = M(r"e:\K\d+")

        # Badness
        b = M(r"y:\K\d+")

        # Get the name by replacing the naughty and nice specifications
        # with empty strings and print the line to STDOUT
        println(replace(l, r" *\w+:\d+ *", ""), " ",
                g > b ? "toys" : b > g ? "coal" : "needs more data")
    end
end


3

रूबी, 144 123 155 * .75 = 116.25 बाइट्स

->s{d={}
s.split("
").map{|l|
a=l.split
b=a.grep /:/
i,j,v=(b.sort*'').scan(/\d+/)+a-b
d[v]||(d[v]=0
puts v+' '+['needs more data','coal','toys'][i<=>j])}}

सुझाव देने की grepविधि के लिए हिस्टोक्रेट का धन्यवाद ।

164 * .75 = 123 बाइट्स

->s{d={}
s.split("
").map{|l|
a=l.split
b=a.select{|t|t[?:]}
i,j,v=(b.sort*'').scan(/\d+/)+a-b
d[v]||(d[v]=0
puts v+' '+['needs more data','coal','toys'][i<=>j])}}

144 बाइट्स

->s{puts s.split("
").map{|l|b=(a=l.split).select{|t|t[?:]};i,j=(b.sort*'').scan(/\d+/);(a-b)[0]+' '+['needs more data','coal','toys'][i<=>j]}}

Ungolfed

->s{
  d={}
  s.split("
  ").map{ |l|
    a = l.split
    b = a.grep /:/
    i, j, v = (b.sort * '').scan(/\d+/) + a-b
    d[v] ||
      (d[v]=0
       puts v + ' ' + ['needs more data','coal','toys'][i<=>j]
      )
  }
}

उपयोग:

# Assign the anonymous function to a variable
f = ->s{d={}
s.split("
").map{|l|
a=l.split
b=a.grep /:/
i,j,v=(b.sort*'').scan(/\d+/)+a-b
d[v]||(d[v]=0
puts v+' '+['needs more data','coal','toys'][i<=>j])}}

f["Quill naughty:4 nice:0
naughty:0 Doorknob nice:3
naughty:2 Quill nice:6
nice:3 balpha naughty:3
pops nice:4 naughty:2"]

Quill coal
Doorknob toys
balpha needs more data
pops toys

.select{|t|t[?:]}.grep(/:/)
can:

@ हिस्टोक्रैट वाह मैं पूरी तरह से उस पद्धति को भूल गया।
साभार

3

पर्ल, 138 113 105 103 102 96 96 - 25% = 72

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

s/ *\w*(.):(\d+) */$$1=$2,()/eg;$$_++?$_='':s/\n/$".('needs more data',toys,coal)[$e<=>$y].$&/e

कम गोल्फ वाला:

s/ *\w*(.):(\d+) */$$1=$2,()/eg;    # strip naughty/nice, set $a to naughty, $i to nice
                                    # $_ is now the input name followed by \n
$$_++ ? $_='' :                     # only output once per name
s/\n/                               # replace newlines with:
  $".                               # a space,
  ('needs more data',toys,coal)     # one of these strings,
  [$e<=>$y]                         # indexed by -1, 0 or 1
  .$&                               # and the matched newline.
/ex                                 # (/x only for legibility)

  • अद्यतन 113
    • से 1 पत्र का उपयोग करके 25 बाइट्स बचाने niceया naughtyचर नाम के रूप में;
    • जब नाम अंतिम हो तो बग को ठीक करके 5 बाइट्स ढीला करें
  • <=>आउटपुट स्ट्रिंग्स की सूची को इंडेक्स करके 8 बाइट्स को अपडेट करने के लिए 105 सेव करें
  • उत्पादन स्ट्रिंग को जोड़ने के लिए regex का उपयोग करके 103 सेव 2 बाइट्स को अपडेट करें
  • 2 के बजाय niceया के अंतिम पत्र का उपयोग करके 102 सेव 1 बाइट को अपडेट करेंnaughty
  • 96 अद्यतन बदलकर 6 बचाने बाइट्स $$_ ? ... : ($$_++, ...)में $$_++ ? ... : ...
    (क्यों मुझे लगता है कि इससे पहले कि नहीं देखा)।

2

जावास्क्रिप्ट (ईएस 6), 174 बाइट्स - 25% बोनस = 130.5 स्कोर

s=>s.split`
`.map(l=>l.split` `.map(p=>(m=p.match(/\w:\d+/))?(n=+m[0].slice(2),m>"f")?b=n:c=n:a=p)&&d[a]?"":d[a]=a+" "+(b>c?`coal
`:b<c?`toys
`:`needs more data
`),d={}).join``

व्याख्या

s=>
  s.split`
`.map(l=>                   // for each line l of Santa's list
    l.split` `.map(p=>      // for each word p in l
      (m=p.match(/\w:\d+/)) // m = "y:x" for naughty, "e:x" for nice or null for name
        ?(n=+m[0].slice(2), // n = number at end of match
          m>"f")?b=n:c=n    // if naughty matched b = n, if nice matched c = n
        :a=p                // if no match, a = name
    )
    &&d[a]?"":              // if the name has been used before, add nothing to output
    d[a]=                   // else set d[name] to true

      // Add the appropriate text to the output
      a+" "+(b>c?`coal
`:b<c?`toys
`:`needs more data
`),

    // NOTE: This line is executed BEFORE the code above it in the map function...
    d={}                    // d = list of names that have been output
  )
  .join``                   // return the list of outputs as a string

परीक्षा



2

लुआ, 329 बाइट्स - 25% बोनस = 246.75

a={...}p={}u=" "k=ipairs for i=1,#a/3 do p[i]={}end for i,v in k(a)do p[math.floor((i+2)/3)][(v:find("y:")and 3)or(v:find("e:")and 2)or 1]=v:gsub("%a+%:","")end for i,v in k(p)do d=tonumber b,g,n=d(v[3]),d(v[2]),v[1]if(not u:find(" "..n.." "))then u=u..n.." "print(n..(g<b and" coal"or g>b and" toys"or" needs more data"))end end

बाद में थोड़े थक गए संस्करण और स्पष्टीकरण में संपादित करेंगे। सभी इनपुट कमांड लाइन के माध्यम से लिया जाता है, अंतरिक्ष को अलग किया जाता है।


2

पायथन 2, 206 बाइट्स - 25% = 154.5

s=[]
x=[0,0]
for p in zip(*(iter(input().split()),)*3):
 for w in p:
  j=w.find(':')+1
  if j:x[j<6]=int(w[j:])
  else:N=w
 b,g=x
 if N not in s:print N,['needs more data','coal','toys'][(b>g)-(g>b)];s+=[N]

2

जावास्क्रिप्ट (ईएस 6) 120 (160-25%)

टेम्प्लेट स्ट्रिंग्स का उपयोग करते हुए बेनामी फ़ंक्शन, 4 नई रूपरेखाएं हैं जो महत्वपूर्ण हैं और बाइट काउंट में शामिल हैं

l=>l.split`
`.map(r=>k[r=r.replace(/\S+:(\d+)/g,(a,c)=>(t-=a[1]<'i'?c:-c,''),t=0).trim()]?'':k[r]=r+(t>0?` toys
`:t<0?` coal
`:` needs more data
`),k={}).join``
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.