सिंकअप का पता लगाएं


33

एक स्ट्रिंग के इनपुट को देखते हुए जिसमें पूरी तरह से qतिमाही नोटों का eप्रतिनिधित्व होता है और आठवें नोटों का प्रतिनिधित्व करता है, तिमाही नोटों के सूचकांकों को आउटपुट किया जाता है जो सिंक किए गए हैं।

सिंक्रनाइज़ेशन जटिल है, लेकिन इस चुनौती के प्रयोजनों के लिए, "समन्वित" की हमारी परिभाषा बहुत सरल होगी: एक चौथाई नोट जो "ऑफ-बीट" पर शुरू होता है - यह है, बीट्स को "और" एन 4 में गिना जाता है। पहर।

यह वैकल्पिक रूप से किसी भी तिमाही नोट के रूप में परिभाषित किया जा सकता है जो आठवें नोटों की विषम संख्या से पहले है। उदाहरण के लिए, *नीचे दिए गए नोटों को समन्वित माना जाता है, और उनके सूचक भी दिखाए जाते हैं:

eqqeqqeqqe
 **    **
 12    78
Output: 1 2 7 8

इनपुट में हमेशा 4/4 समय में एक पूरी संख्या शामिल होगी (एक चौथाई नोट एक माप का एक चौथाई है, और आठवां नोट एक माप का आठवां है)। (इनपुट भी कभी भी खाली नहीं होगा।) आउटपुट या तो किसी भी सीमांकक द्वारा अलग किए गए तत्वों के साथ एक ही स्ट्रिंग हो सकता है जिसमें नंबर या कोई सरणी / सूची / आदि शामिल नहीं है। यदि आप चाहें तो आउटपुट 1-आधारित हो सकता है (यानी पहला इंडेक्स 0 के बजाय 1 है), और यह किसी भी संख्यात्मक आधार (यूनीरी, दशमलव, आदि) में भी हो सकता है।

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

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

In                        Out
-----------------------------------------------
eqqqe                     1 2 3
qeqeq                     2
qqqeqqeeeeqeqeqeqqeqqeqq  4 5 10 14 19 20
eeeeeqeeqeeqqqqeqeqeeqe   5 8 11 12 13 14 18 21
qqqq                      <none>
eeeeeeee                  <none>

1
क्या आउटपुट 1-आधारित हो सकता है?
लुइस मेंडो

1
क्या आप यह दिखाने के लिए काम कर सकते हैं कि सूचकांक कैसे काम करते हैं?
पीटर टेलर

1
@LuisMendo ज़रूर, अगर यह आपके कोड को छोटा बनाता है।
दरवाज़े

@PeterTaylor ठीक है, क्या कुछ ऐसा है जो आप सोच रहे थे?
दरवाज़े

क्या इनपुट उद्धरण चिह्नों सहित एक स्ट्रिंग हो सकता है? 'eqqqe'इसके बजायeqqqe
लुइस मेंडो

जवाबों:


12

जेली , 12 9 बाइट्स

=“e”µ<^\O

एक कार्यक्रम के रूप में, उपरोक्त कोड को इनपुट के आसपास उद्धरणों की आवश्यकता होती है। चूंकि इसकी अनुमति नहीं है, इसलिए यह एक फ़ंक्शन सबमिशन है। आउटपुट 1-आधारित है। इसे ऑनलाइन आज़माएं!

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

=“e”µ<^\O    Monadic link. Argument: s (string)

=“e”         Check each character for equality with 'e'. Yields a Boolean array.
    µ        Start a new, monadic chain.
      ^\     Compute the array of partial reductions by XOR, i. e., the parities
             of all prefixes of the Boolean array.
     <       Check if the Booleans are strictly smaller than the parities.
             A truthy outcome indicates an off-beat quarter note.
        O    Yield all indices of 1's.

अद्यतन करें

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

=”eµ<^\O

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


7

रूबी, ४६

i=e=0
gets.bytes{|n|e^=n
e&4|n>114&&p(i)
i+=1}

स्टड के लिए इनपुट। स्टडआउट के लिए आउटपुट, न्यूलाइन अलग हो गया।

टिप्पणी की गई

i=e=0               #i keeps index, e keeps track of 8ths.
gets.bytes{|n|      #iterate through bytes in the input
e^=n                #xor e with input. We're interested in the 4's bit, which is only affected by ascii e, not ascii q
e&4|n>114&&p(i)     #e&4 evaluates to 4 or 0. OR with n and if the value is greater than ascii code for q, print index
i+=1}               #increment index

6

जावास्क्रिप्ट ईएस 7, 50 48 बाइट्स

जेएस के लिए बहुत छोटा है, अगर आप मुझसे पूछें। [for...of]सिंटैक्स, मूल रूप से संयुक्त नक्शा और फ़िल्टर, इस चुनौती के लिए काम में आता है।

s=>[for(c of(i=f=0,s))if(++i&&c>'e'?f%2:f++&0)i]

एक अनाम फ़ंक्शन को परिभाषित करता है जो 1-अनुक्रमित सरणी को आउटपुट करता है।

टेस्ट स्निपेट

यह कोड का एक ungolfed, संयुक्त राष्ट्र ES7'd संस्करण का उपयोग करता है।

a = function(s) {   // Create a function a that takes in a parameter s and does these things:
  var r = [],       // Set variable r to an empty array,
  i = 0, f = 0;     // i to 0, and f to 0.
  for(c of s) {     // For each character c in s:
    i++;            //  Increment i by 1.
    if(             //  If
      c == 'q' ?    //   if c == 'q',
      f%2 === 1 :   //    f is even; otherwise,
      f++ && false) //    increment f and don't execute this:
      r.push(i);    //   Add i to the end of r.
  } return r;       // Return r.
}
<input type="text" value="eqqqe" id=O />
<button onclick="P.innerHTML='['+a(O.value)+']'">Try it</button>
<p id=P />


3
बहुत अच्छी व्याख्या! और ES7 के नए [For ...]
use

तो, क्या हमें एक नए प्रश्न की आवश्यकता है, "ईसीएमएस्क्रिप्ट 7 में गोल्फिंग के लिए टिप्स"?
नील

@ नील मैंने ES6 / 7 को ES6 पोस्ट अपडेट करने की कोशिश की, लेकिन ओपी ने एडिट को वापस ले लिया। इस बीच, यह है: codegolf.stackexchange.com/a/61489/42545
22

5

जे, 20 19 17 बाइट्स

=&'e'(I.@:<~:/\@)

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

  f =: =&'e'(I.@:<~:/\@)
  f 'eqqqe'
1 2 3

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

व्याख्या

=&'e'(I.@:<~:/\@)
=&'e'               Replace every 'e' with 1, other chars with 0
     (         @)   Apply the verb in parentheses to the resulting 0-1 vector
           ~:/\     Cumulative reduce with XOR (parity of 'e'-chars to the left)
          <         Element-wise less-than with original vector
      I.@:          Positions of 1s in that vector

5

GNU grep, 3 + 17 = 20 3 + 15 = 18 बाइट्स

कार्यक्रम के लिए विकल्पों की आवश्यकता होती है boP। कोड है

q(?!(q|eq*e)*$)

इसे बचाने के रूप में synco, फिर के रूप में चलाते हैं grep -boPf synco

आउटपुट विभाजक के :qबाद एक नई रेखा होती है। जैसे के लिए आउटपुट eqqqeहै

1:q
2:q
3:q

झंडों के अर्थ हैं:

  • P: PCRE regexes का उपयोग करें।
  • o: इसका मतलब है कि नियमित अभिव्यक्ति से मेल खाने वाले लाइन का केवल एक भाग प्रिंट करना, लेकिन यह महत्वपूर्ण नहीं है। oका उपयोग किया जाता है क्योंकि इसमें प्रति पंक्ति कई मैचों की अनुमति देने का प्रभाव होता है।
  • b: फाइल की शुरुआत से प्रत्येक मैच की शुरुआत के बाइट्स में ऑफसेट प्रिंट करें।

पैटर्न जाँचता है कि एक चौथाई नोट के बाद आठवें नोट की संख्या भी नहीं है।


क्या grepअपने आप में एक भाषा के रूप में योग्य है? भले ही, एक महान जवाब के लिए +1
डिजिटल ट्रॉमा

@DigitalTrauma मैं नहीं देखता कि क्यों नहीं ... यह PCRE regexes का उपयोग कर सकता है, इसलिए इसे कम से कम ट्यूरिंग-पूर्ण होना चाहिए, और यहां दिखाए गए अनुसार फ़ाइल से कोड निष्पादित कर सकता है।
feersum

मैं इस धारणा के तहत था कि पीसीआरई ट्यूरिंग पूरी तरह से सिद्ध नहीं है। भले ही, आपकी अभिव्यक्ति की आवश्यकता पूरी हो, इसलिए मैं इसके साथ ठीक हूं, लेकिन सैद्धांतिक आधार पर शिकायतों के साथ अन्य भी हो सकते हैं।
डिजिटल ट्रॉमा

@DigitalTrauma हुह, लगता है कि मैं ट्यूरिंग-पूर्णता के बारे में बहक गया था।
feersum

5

MATL , 12 14 16 बाइट्स

j101=tYs2\<f

2 बाइट्स निकालने के लिए डेनिस के लिए धन्यवाद (और अपने भयानक ऑनलाइन प्लेटफॉर्म में MATL की मेजबानी के लिए!)

यह भाषा / संकलक के वर्तमान संस्करण (9.3.0) का उपयोग करता है ।

इनपुट और आउटपुट स्टड और स्टडआउट के माध्यम से हैं। परिणाम 1-आधारित है।

उदाहरण :

>> matl j101=tYs2\<f
> eeeeeqeeqeeqqqqeqeqeeqe
6  9 12 13 14 15 19 22

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

व्याख्या

j             % input string
101=          % vector that equals 1 at 'e' characters and 0 otherwise
t             % duplicate
Ys2\          % cumulative sum modulo 2
<             % detect where first vector is 0 and second is 1
f             % find (1-based) indices of nonzero values

3

पायथन 2, 94 85 79 75 66 बाइट्स

संपादित करें: धन्यवाद Doorknob और एलेक्स ए।

संपादित करें: धन्यवाद एलेक्स ए।

संपादित करें: अब इनपुट () का उपयोग करके इनपुट को उद्धरण के साथ एक स्ट्रिंग होना चाहिए।

संपादित करें: Enumerate का उपयोग करने के लिए मुझे सिफारिश करने के लिए धन्यवाद Zgarb।

बस ई की संख्या गिना जाता है और यदि q, जाँच करें कि क्या ई गणना विषम है, तो प्रिंट इंडेक्स।

e=0
for j,k in enumerate(input()):
 if"q">k:e+=1
 elif e%2:print j

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


आप 8 बाइट्स को बचाने के लिए if ...सिर्फ एक के साथ दूसरा बदल सकते हैं else
दरवाज़े

आप print1 बाइट के लिए स्थान भी निकाल सकते हैं
एलेक्स ए।

मुझे लगता है कि आप इसे else: if e%2:सिर्फ बदल सकते हैं elif e%2:
एलेक्स ए।

के i[j]<"q"बजाय जाँच करके आप एक और बाइट बचा सकते हैं i[j]=="e"
एलेक्स ए।

2
@ तन्माथ ने मैंने डोरकनॉब से पूछा क्योंकि यह मुझे उद्धरणों के साथ एक इनपुट लेने के लिए 2 बाइट्स बचाएगा। लेकिन यह नहीं किया जा सकता है
लुइस मेंडो

3

हास्केल, 58 51 बाइट्स

f x=[i|(i,'q')<-zip[0..]x,odd$sum[1|'e'<-take i x]]

प्रयोग उदाहरण: f "eeeeeqeeqeeqqqqeqeqeeqe"-> [5,8,11,12,13,14,18,21]

सूची के माध्यम से जाओ और iहर चार के लिए वर्तमान सूचकांक का उत्पादन 'q'अगर वहाँ 'e'से पहले एक विषम संख्या है।


2

मिंकोलंग 0.15 , 28 बाइट्स

(o"q"=7&z1+$z8!z2%,2&iN$I$).

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

व्याख्या

(                        Open while loop
 o                       Read in character from input
  "q"                    Push the character "q"
     =                   1 if the top two items on stack are equal, 0 otherwise
      7&                 Pop and jump 7 spaces if truthy

        z                Push register value on stack
         1+              Add one
           $z            Pop top of stack and store in register
             8!          Jump eight spaces

        z                Push register value on stack
         2%              Modulo by 2
           ,             boolean not
            2&           Pop and jump two spaces if truthy
              i          Push loop counter
               N         Output as number

                $I       Push length of input
                  $).    Close while loop when top of stack is 0 and stop.

2

सी (फ़ंक्शन), 65

अतिरिक्त गोल्फ के लिए @ डेनिस का धन्यवाद!

i,n;f(char*m){for(i=n=0;*m;i++)*m++&4?++n:n%2?printf("%d ",i):0;}

1
मुझे लगता है कि i,n;f(char*m){for(i=n=0;*m;m++,i++)*m&4?++n:n%2?printf("%d ",i):0;}काम करना चाहिए।
डेनिस

2

पायथन 3, 109 95 80 90 88 76 68 67 66 64 बाइट्स

यदि qs और es की संख्या को गिना जाता है और qपूर्ववर्ती es की संख्या विषम है , तो करंट के सूचकांक को जोड़ता है।

संपादित करें: अब यह s के सूचकांकों की एक सूची बनाता है qजो एक विषम संख्या है और eउनमें पूर्ववर्ती संख्या विषम है। आठ बाइट्स के लिए धन्यवाद बचाया दरवाज़े और दो और धन्यवाद करने के लिए feersum

lambda s:[x for x,m in enumerate(s)if("e"<m)*s[:x].count("e")%2]

Ungolfed:

def f(s):
    c = []
    for index, item in enumerate(s):
        if item == "q":
            if s[:index].count("e")%2 == 1:
                c.append(index)
    return c

1
क्या आप इसे inputऔर printबयानों को अनावश्यक बनाने के लिए एक मेमना नहीं बना सकते थे ?
दरवाज़े

इसके enumerateबजाय उपयोग करने के लिए कम होना चाहिए range(len(...
23

2

जावास्क्रिप्ट ईएस 6, 63 60 58 बाइट्स

x=>[...x].map((e,i)=>e>'e'?n%2&&a.push(i):n++,a=[],n=0)&&a

अनाम फ़ंक्शन जो किसी सरणी को आउटपुट करता है। दो बाइट्स बचाने के लिए user81655 का धन्यवाद। यहाँ एक ungolfed संस्करण है जो बेहतर समर्थित सिंटैक्स का उपयोग करता है।

f=function(x) {
  a=[] // Indeces of syncopated notes
  n=0 // Number of e's encountered so far
  x.split('').map(function(e,i) { // For each letter...
    e>'e'? // If the letter is q...
      n%2&& // ...and the number of e's is odd...
        a.push(i): // ...add the current index to the array
      n++ // Otherwise, it is e so increment the counter
  })
  return a
}

run=function(){document.getElementById('output').textContent=f(document.getElementById('input').value)};document.getElementById('run').onclick=run;run()
<input type="text" id="input" value="qqqeqqeeeeqeqeqeqqeqqeqq" /><button id="run">Run</button><br />
<samp id="output"></samp>


0

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

Flatten[Range[#+1,#2-1]&@@@StringPosition[#,"e"~~"q"..~~"e",Overlaps->1<0]]&

कुछ दिलचस्प मैंने देखा। सभी सिंक किए गए भाग फॉर्म के हैं eqqq..qqe, इसलिए मैं केवल उन का पता लगाता हूं और एस के सूचकांक देता हूं q


0

जाप, २ ९ २३ २१ बाइट्स

अब गैर-प्रतिस्पर्धा नहीं!

0+U ¬®¥'e} å^ ä© m© f

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

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

         // Implicit: U = input string, e.g.    "eqqeqeq"
0+U      // Add a 0 to the beginning.           "0eqqeqeq"
¬        // Split into chars.                   ['0,'e,'q,'q,'e,'q,'e,'q]
®¥'e}    // Map each item X to (X == 'e).       [F, T, F, F, T, F, T, F]
å^       // Cumulative reduce by XOR'ing.       [0, 1, 1, 1, 0, 0, 1, 1]
ä©       // Map each consecutive pair with &&.  [0, 1, 1, 0, 0, 0, 1]
m©       // Map each item with &&. This performs (item && index):
         //                                     [0, 1, 2, 0, 0, 0, 6]
f        // Filter out the falsy items.         [   1, 2,          6]
         // Implicit output                     [1,2,6]

गैर-प्रतिस्पर्धात्मक संस्करण, 18 बाइट्स

U¬m¥'e å^ ä©0 m© f

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


0

बेगुंज, 43 बाइट्स

:~:0\`#@_5%2/:99p1++\>2%#<9#\9#.g#:*#\_\1+\

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

व्याख्या

हम स्टैक पर दो निहित शून्य से शुरू करते हैं: नोट संख्या, और एक बीट काउंट।

:               Make a duplicate of the beat count.
~               Read a character from stdin.
:0\`#@_         Exit if it's less than zero (i.e. end-of-file).
5%2/            Take the ASCII value mod 5, div 2, translating q to 1 and e to 0.
:99p            Save a copy in memory for later use.
1+              Add 1, so q maps to 2 and e to 1.
+               Then add that number to our beat count.
\               Get the original beat count that we duplicated at the start.
2%              Mod 2 to check if it's an off-beat.
99g*            Multiply with the previously saved note number (1 for q, 0 for e).
_               Essentially testing if it's a quarter note on an off-beat.
       \.:\     If true, we go turn back left, get the beat count, and output it.
         >2     Then push 2 onto the stack, and turn right again.
2%              That 2 modulo 2 is just zero.
99g*            Then multiplied by the saved note number is still zero.
_               And thus we branch right on the second pass.
\1+\            Finally we increment the note number and wrap around to the start again.
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.