गुप्त ">" स्टैकिंग चैलेंज: ग्रेडिंग

Aug 18 2020

पृष्ठभूमि

टेट्रिस ग्रैंड मास्टर 3 में खेल के अंत में स्टैक के आकार के आधार पर एक छिपी हुई ग्रेडिंग प्रणाली है, जिसे गुप्त ">" स्टैकिंग चैलेंज कहा जाता है । इसमें पूरी तरह से सबसे निचली पंक्तियों को शामिल किया गया है सिवाय उस ज़िगज़ैग पैटर्न के जो बायीं तरफ के सेल से शुरू होता है और पूरी चौड़ाई फैलाता है:

#
.#########
#.########
##.#######
###.######
####.#####
#####.####
######.###
#######.##
########.#
#########.
########.#
#######.##
######.###
#####.####
####.#####
###.######
##.#######
#.########
.#########

बोर्ड को यह दर्शाया जाता है कि नीचे की रेखा से कितनी लाइनें इस सटीक पैटर्न का अनुसरण करती हैं। ध्यान दें कि पैटर्न के सबसे ऊपरी छेद को ब्लॉक के एक अतिरिक्त टुकड़े द्वारा अवरुद्ध किया जाना चाहिए। यदि आप #एस और .एस को अनिवार्य पैटर्न मानते हैं (रिक्त कुछ भी हो सकता है), तो आप केवल 19 का स्कोर प्राप्त कर सकते हैं यदि उपरोक्त पैटर्न नीचे की रेखा से मेल खाता है। यदि बोर्ड इस पैटर्न से मेल खाता है, तो एनालॉग रूप से

   #
###.######
##.#######
#.########
.#########

लेकिन नहीं

    #
####.#####
###.######
##.#######
#.########
.#########

फिर स्कोर 4 है।

इस चुनौती के लिए, मनमाने आकार के बोर्ड पर विचार करें (20 से अधिक कोशिकाओं और 10 कोशिकाओं से अधिक चौड़ा)। हम एक ही पैटर्न के लिए बोर्ड को ग्रेड कर सकते हैं: उदाहरण के लिए, यदि बोर्ड की चौड़ाई 4 है, तो यह स्कोर 3 के लिए पैटर्न है:

  #
##.#
#.##
.###

और यह स्कोर 10 के लिए पैटर्न है:

   #
###.
##.#
#.##
.###
#.##
##.#
###.
##.#
#.##
.###

चुनौती

टेट्रिस बोर्ड ऑफ़ अनियंत्रित आकार की अंतिम स्थिति को देखते हुए, ऊपर दिए सिस्टम का उपयोग करके बोर्ड को ग्रेड दें।

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

मानक कोड-गोल्फ नियम लागू होते हैं। बाइट्स में सबसे छोटा कोड जीतता है।

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

संभव भ्रम को रोकने के लिए, यहां परीक्षण मामले Oब्लॉक और .खाली स्थानों के लिए उपयोग करते हैं ।

Input:
..O.O
OOOO.
OOO..
OO.OO
O.OOO
.OOOO
Output: 3

Input:
..
O.
.O
.O
O.
.O
O.
.O
Output: 4

Input:
.OOO
O.OO
OO.O
OO.O
OO.O
O.OO
.OOO
Output: 2 (any lines above the first non-conforming line are ignored;
           doesn't get 3 because 3rd line's hole is not capped)

Input:
OOO.
.OOO
O.OO
OO.O
OOO.
OO.O
O.OO
Output: 0 (Wrong starting hole)

Input:
.OOO
O.OO
OO.O
OOO.
Output: 0 (Wrong starting hole)

Input:
.OOO
.OOO
Output: 0 (Hole is not covered)

Input:
OOO...O..O
.OOOOOOOOO
O.OOOOOOOO
OO.OOOOOOO
OOO.OOOOOO
OOOO.OOOOO
OOOOO.OOOO
OOOOOO.OOO
OOOOOOO.OO
OOOOOOOO.O
OOOOOOOOO.
OOOOOOOO.O
OOOOOOO.OO
OOOOOO.OOO
OOOOO.OOOO
OOOO.OOOOO
OOO.OOOOOO
OO.OOOOOOO
O.OOOOOOOO
.OOOOOOOOO
Output: 19

जवाब

3 Arnauld Aug 18 2020 at 12:47

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

1खाली स्थानों के लिए और 0ब्लॉकों के साथ, तार की एक सूची की अपेक्षा करता है ।

f=(a,i=j=1<<a[k=0].length)=>(v='0b'+a.pop()+0)^i?v&i/k&&-1:1+f(a,i*=k=i&j?.5:i&2||k)

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

कैसे?

इनपुट सरणी में प्रत्येक स्ट्रिंग को एक अतिरिक्त के साथ गद्देदार किया जाता है 0और एक बाइनरी नंबर के रूप में व्याख्या की जाती है। चर jको आरंभीकृत किया जाता है 2**W, जहां Wबोर्ड की चौड़ाई होती है। हम पैटर्न में छेद की अपेक्षित स्थिति का ट्रैक रखने के iलिए आरंभ में थोड़ा सा मास्क का उपयोग करते हैं j

प्रत्येक पुनरावृत्ति के बाद, iद्वारा गुणा किया जाता है k। हम kजब भी (i & j) != 0(बाईं ओर (i & 2) != 0उछलते हुए ) या (सबसे दाईं ओर उछलते हुए ) का मान अपडेट करते हैं ।

इसके लिए उदाहरण W = 5:

j = 0b100000

i = 0b100000 // -> set k to 1/2
i = 0b010000 // \
i = 0b001000 //  }-> leave k unchanged
i = 0b000100 // /
i = 0b000010 // -> set k to 2
i = 0b000100 // \
i = 0b001000 //  }-> leave k unchanged
i = 0b010000 // /
i = 0b100000 // -> set k to 1/2
...

टिप्पणी की गई

f = (                // f is a recursive function taking:
  a,                 //   a[] = input array
  i = j =            //   i = hole bit mask, initialized to ...
    1 << a[k = 0]    //   ... j = 2 ** W, where W is the width of the board
         .length     //   k = bit mask multiplier, initialized to 0
) =>                 //
( v =                // pop the last value from a[], append a '0' and interpret
  '0b' + a.pop() + 0 // it as a binary number saved in v
) ^ i ?              // if v is not equal to i:
  v & i / k          //   use the previous bit mask i / k to test whether there's
  && -1              //   a hole in v above the last hole of the pattern, in
                     //   which case we subtract 1 from the final result
:                    // else:
  1 +                //   add 1 to the final result
  f(                 //   do a recursive call:
    a,               //     pass a[] unchanged
    i *=             //     multiply i by:
      k =            //       the new value of k:
        i & j ?      //         if we've reached the leftmost side:
          .5         //           set k to 1/2
        :            //         else:
          i & 2      //           set k to 2 if we've reached the rightmost side,
          || k       //           or leave k unchanged otherwise
  )                  //   end of recursive call
3 Zgarb Aug 20 2020 at 04:54

हस्क , 18 बाइट्स

Lδ↑€…¢ŀT¹↑εΨ↑-↔m¥0

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

एक 0-1 मैट्रिक्स लेता है।

व्याख्या

इस कार्यक्रम की तीन घटनाएं हैं , और वे सभी संशोधक कार्यों के लिए अलग-अलग धन्यवाद करते हैं δऔर Ψ। डिफ़ॉल्ट रूप से, एक असमान फ़ंक्शन होने की ↑αअपेक्षा αकरता है, एक सूची लेता है और तत्वों का सबसे लंबा उपसर्ग αदेता है जिसके लिए एक सत्य मान देता है। द्विआधारी होने की Ψ↑αउम्मीद αहै, और तत्वों का सबसे लंबा उपसर्ग लौटाता है xजिसके α x yलिए सत्य है, yअगला तत्व कहां है। द्विआधारी होने की δ↑αउम्मीद αहै और एक के बजाय दो सूची लेता है। यह दूसरी सूची का सबसे लंबा उपसर्ग लौटाता है जिसके तत्व yसंतुष्ट करते हैं α x y, जहां xपहली सूची का संबंधित तत्व है।

Input is a list of lists of integers.
Example: [[0,1,1],[1,0,1],[1,1,0],[1,0,1],[1,1,0],[0,0,1],[0,1,1]]

m     Map
 ¥0   indices where 0 occurs:
        [[1],[1,2],[3],[2],[3],[2],[1]]
↔     Reverse:
        [[1],[2],[3],[2],[3],[1,2],[1]]

 ↑    Take while
Ψ     this element and the next
  -   have nonempty set difference:
        [[1],[2],[3],[2],[3],[1,2]]

↑     Take while
 ε    this element is a singleton:
        [[1],[2],[3],[2],[3]]
      Call this list X.

ŀT¹   Indices of input transposed:
        [1,2,3]
¢     Cycle infinitely:
        [1,2,3,1,2,3,..]
…     Rangify:
        [1,2,3,2,1,2,3,2,1,..]
 ↑    Take from X while
δ     the corresponding integer in this list
  €   is an element of it:
        [[1],[2],[3],[2]]
L     Length: 4
2 Neil Aug 18 2020 at 19:06

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

WS⊞υι≔⮌υυP⪫υ¶W∧⁼.O⪫KD²↓ω⁼¹№§υⅉ.M✳⁻⁷⊗÷﹪ⅉ⊗⊖Lθ⊖Lθ≔ⅉθ⎚Iθ

इसे ऑनलाइन आज़माएं! लिंक कोड के वर्बोज़ संस्करण के लिए है। इनपुट के तार .और Oपात्रों की एक नई-पंक्तिबद्ध सूची के रूप में इनपुट लेता है । स्पष्टीकरण:

WS⊞υι

सूची इनपुट करें

≔⮌υυ

सूची को उलट दें।

P⪫υ¶

कर्सर को स्थानांतरित किए बिना सूची को प्रिंट करें।

W∧

दोनों को दोहराते हुए ...

⁼.O⪫KD²↓ω

... कर्सर के .नीचे का वर्ण a और नीचे का वर्ण है (क्योंकि सूची को उलट दिया गया था) a O, और ...

⁼¹№§υⅉ.

... वर्तमान सूची लाइन में ठीक एक शामिल है .:

M✳⁻⁷⊗÷﹪ⅉ⊗⊖Lθ⊖Lθ

पंक्ति के आधार पर कर्सर को तिरछे और नीचे या दाएं या बाएं घुमाएं।

≔ⅉθ⎚Iθ

पहली अमान्य पंक्ति सूचकांक (0-अनुक्रमित, इसलिए मान्य पंक्तियों की संख्या के बराबर) पर कब्जा करें, कैनवास को साफ़ करें, और इसे स्ट्रिंग के रूप में प्रिंट करें।

2 xash Aug 18 2020 at 12:33

जम्मू , 57 42 बाइट्स

अवरुद्ध के लिए 0 में लेता है, खाली के लिए 1।

[:#.~(|.@$2^|@}:@i:@<:)/@$=2#.[*[+_1|.!.2]

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

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

[*[+_1|.!.2]

बोर्ड को एक से नीचे शिफ्ट करें (2 शीर्ष पर धकेल दिया जाता है यह सुनिश्चित करने के लिए कि शीर्ष स्पॉट गिनती नहीं करते हैं।) फिर यह मूल बोर्ड में जुड़ जाता है और अपने आप से कई गुना बढ़ जाता है। यह मूल रूप से उबलता है: एक वैध खुला स्थान 1 रहता है, जबकि अमान्य 2 बन जाते हैं।

 (|.@$2^|@}:@i:@<:)/@$

आयामों को देखते हुए, -x … x - 1चौड़ाई 4 के लिए अनन्य रेंज प्राप्त करें , उदाहरण के लिए: 4 _3 _2 _1 0 1 2, और उनके पूर्ण मान प्राप्त करें 3 2 1 0 1 2। उस सूची को बोर्ड की ऊंचाई पर आकार दें, इसे घुमाएं ताकि आरंभिक 3 अंतिम पंक्ति में संरेखित हो, और 2^xसूची:8 4 2 1 2 4 8 4 2…

 =2#.

आधार 2 नंबर के रूप में पंक्तियों की व्याख्या करें और इसे ज़िग-ज़ैग सूची से तुलना करें।

 [:#.~

और रिफ्लेक्टिव बेस रूपांतरण से हम अग्रणी 1 की गिनती कर सकते हैं, इसलिए अग्रणी पंक्तियाँ जो मान्य हैं।

1 JonathanAllan Aug 19 2020 at 17:47

जेली , 25 बाइट्स

ZJŒḄṖṁLW€⁻"ⱮṚT€,Ḋ$ƊZḄCTḢ’

एक मोनडिक लिंक, उन पंक्तियों की एक सूची को स्वीकार करता है जहाँ प्रत्येक पंक्ति 1s (खाली) और 0s (भरी) की सूची है जो एक गैर-नकारात्मक पूर्णांक (स्कोर) प्राप्त करता है।

इसे ऑनलाइन आज़माएं! या परीक्षण-सूट देखें ।

कैसे?

नीचे से प्रत्येक पंक्ति के लिए अपेक्षित खाली सूचकांकों की सूची बनाता है और प्रत्येक दो सूचियों, (क) वास्तविक खाली सूचकांकों और (ख) वास्तविक खाली सूचकांकों की तुलना करता है। इस तुलना के परिणामों को फिर स्कोर खोजने के लिए संसाधित किया जाता है।

ZJŒḄṖṁLW€⁻"ⱮṚT€,Ḋ$ƊZḄCTḢ’ - Link: list of lines, A
Z                         - transpose
 J                        - range of length     -> [1,2,...,w=#Columns]
  ŒḄ                      - bounce              -> [1,2,...,w-1,w,w-1,...,2,1]
    Ṗ                     - pop                 -> [1,2,...,w-1,w,w-1,...,2]
      L                   - length (A)          -> h=#Lines
     ṁ                    - mould like (repeat Ṗ result such that it is length h)
       W€                 - wrap each of these integers in a list (call this x)
                  Ɗ       - last three links as a monad - i.e. f(A):
            Ṛ             -   reverse (A)
             T€           -   for each (line) get the list of truthy ("empty") indices
                 $        -   last two links as a monad - i.e. f(z=that):
                Ḋ         -     dequeue (drop the leftmost)
               ,          -     (z) pair (that)
           Ɱ              - map across (the two results of f(A)) applying:
          "               -   (x) zip with (result) applying:
         ⁻                -     not equal?
                   Z      - transpose - now we have leading [0,1]'s for valid rows
                                        from the bottom up
                    Ḅ     - convert from binary - now leading 1s for valid rows
                     C    - complement (subtract (each) from one)
                      T   - truthy indices
                       Ḣ  - head
                        ’ - decrement
1 KevinCruijssen Aug 21 2020 at 10:39

05AB1E , 32 बाइट्स

R©εDgݨû¨NèDU._ƶO®N>èX.__н*Θ}γнO

1s और 0s के एक मैट्रिक्स के रूप में इनपुट, जहां 1s रिक्त स्थान हैं और 0s भरे हुए सेल हैं।

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

स्पष्टीकरण:

R             # Reverse the rows of the (implicit) input-matrix
 ©            # Store it in variable `®` (without popping)
  ε           # Map over each row:
   Dg         #  Get the width of the matrix
     Ý        #  Push a list in the range [0,width]
      ¨       #  Remove the last element to change the range to [0,width-1]
       û      #  Palindromize it: [0,1,2,...,w-2,w-1,w-2,...,2,1,0]
        ¨     #  Remove the last value: [0,1,2,...,w-2,w-1,w-2,...,2,1]
         Nè   #  Index the map-index into this list
           DU #  Store a copy in variable `X`
    ._        #  Rotate the current row that many times to the left
      ƶ       #  Multiply each value by its 1-based index
       O      #  And sum this list
   ®          #  Push the reversed input-matrix again from variable `®`
    N>è       #  Index the map-index + 1 into this to get the next row
       X._    #  Also rotate it `X` amount of times towards the left
          _   #  Invert all booleans (1s becomes 0s, and vice-versa)
           н  #  And only leave the first value
   *          #  Multiply both together
    Θ         #  And check that it's equal to 1 (1 if 1; 0 otherwise)
  }γ          # After the map: split the list into groups of adjacent equivalent values
    н         # Only leave the first group
     O        # And take the sum of that
              # (after which it is output implicitly as result)