उस सूची में कितने लाठी क्रम हैं?


21

आपका कार्य यह पता लगाना है कि 12 कार्डों की ऑर्डर की गई सूची में कितने अलग-अलग लाठी क्रम मिल सकते हैं।

एक ब्लैकजैक अनुक्रम को लगातार कार्ड के अनुक्रम के रूप में परिभाषित किया जाता है, जिसके अंकों का योग 21 है। अंक निम्न तालिका के अनुसार गिने जाते हैं:

Symbol | Name  | Points     Symbol | Name  | Points
-------+-------+--------    -------+-------+--------
   2   | Two   | 2             9   | Nine  | 9
   3   | Three | 3             T   | Ten   | 10
   4   | Four  | 4             J   | Jack  | 10
   5   | Five  | 5             Q   | Queen | 10
   6   | Six   | 6             K   | King  | 10
   7   | Seven | 7             A   | Ace   | 1 or 11
   8   | Eight | 8

इनपुट

एक 12-वर्ण स्ट्रिंग, ऊपर वर्णित प्रतीकों का उपयोग कर। हम कार्ड के रंगों के बारे में परवाह नहीं करते हैं, इसलिए उन्हें प्रदान नहीं किया जाता है।

उदाहरण:

K6K6JA3Q4389

उत्पादन

इनपुट स्ट्रिंग में पाया जा सकता है कि अलग डांडा क्रम की संख्या।

उदाहरण:

K6K6JA3Q4389 दो अलग लाठी क्रम शामिल हैं:

उदाहरण

  • JA, ऐस के साथ 11 अंक (10 + 11 = 21) गिना जा रहा है
  • A3Q43, ऐस को 1 अंक (1 + 3 + 10 + 4 + 3 = 21) के रूप में गिना जा रहा है।

तो जवाब होगा 2

नियम

  • दो ब्लैकजैक अनुक्रमों को अलग-अलग माना जाता है यदि उनके पास अलग-अलग क्रम में एक ही कार्ड या एक ही कार्ड होता है। यदि इनपुट सूची में विभिन्न पदों पर सटीक एक ही अनुक्रम दिखाई देता है, तो इसे केवल एक बार गिना जाना चाहिए।
  • लाठी अनुक्रम एक दूसरे को ओवरलैप कर सकते हैं।
  • प्रत्येक प्रकार के कार्ड अनुक्रम में 12 गुना तक दिखाई दे सकते हैं। (हम मानते हैं कि कार्ड कम से कम 3 अलग-अलग डेक से चुने गए हैं।)
  • यदि कोई ब्लैकजैक अनुक्रम इनपुट स्ट्रिंग में नहीं पाया जा सकता है, तो आपको वापस लौटना चाहिए 0या किसी अन्य गलत मूल्य पर।
  • यह कोड-गोल्फ है, इसलिए बाइट्स में सबसे कम जवाब जीतता है। मानक खामियों को मना किया जाता है।

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

जानकारी के प्रयोजनों के लिए अनुक्रम प्रदान किए जाते हैं, लेकिन आपको केवल उनमें से संख्याओं को आउटपुट करने की आवश्यकता होती है।

Input        | Output | Distinct sequences
-------------+--------+--------------------------------------------------------
3282486Q3362 | 0      | (none)
58A24JJ6TK67 | 1      | 8A2
Q745Q745Q745 | 1      | Q74
AAAAAAAAAAAA | 1      | AAAAAAAAAAA
T5AQ26T39QK6 | 2      | AQ, 26T3
JQ4A4427464K | 3      | A442, 44274, 7464
Q74Q74Q74Q74 | 3      | Q74, 74Q, 4Q7
37AQKA3A4758 | 7      | 37A, 37AQ, AQ, AQK, QKA, KA, A3A475
TAQA2JA7AJQA | 10     | TA, TAQ, AQ, QA, A2JA7, 2JA7A, JA, AJ, AJQ, JQA
TAJAQAKAT777 | 13     | TA, TAJ, AJ, JA, JAQ, AQ, QA, QAK, AK, KA, KAT, AT, 777

1
हम्म, क्या दृश्यों की लंबाई 5 या उससे कम नहीं होनी चाहिए?
जोनाथन एलन

@JonathanAllan यह एक अच्छी बात है। मुझे लगता है कि यह वास्तव में एक कैसीनो में सीमा होगी। लेकिन यह कोई वास्तविक लाठी खेल नहीं है। इसके बजाय, मैंने इनपुट को 12 कार्डों तक सीमित करने के लिए चुना है ताकि कई इक्के को बहुत अधिक गणना समय की आवश्यकता न हो। क्या यह ठीक है?
अर्नुलद

अगली चुनौती: सबसे अनोखे ब्लैकजैक अनुक्रम के साथ 12-चार स्ट्रिंग का पता लगाएं: D
ETHproductions

10 कार्ड तक इनपुट सीमित करना इतना आसान होता ...
नील

@ नील ठीक है, जिसने 'इक्के इक्के' के मामले को असंभव बना दिया होगा, लेकिन क्या वास्तव में इसके पीछे एक महत्वपूर्ण अनुकूलन है? मुझे लगता है कि आपके मन में कुछ और हो सकता है।
अरनुलद

जवाबों:


6

जेली , 30 29 बाइट्स

1e×5,⁵Ḥ‘
O_48«26%⁴µSeÇ
ẆÇÐfQL

यह ऑनलाइन की कोशिश करो! या परीक्षण सूट की जाँच करें

कैसे?

ध्यान दें कि, यदि हम हमेशा एक इक्का को 1 मान देते हैं, तो एकमात्र वैध राशि 21 और 11 हैं , बाद वाला स्वीकार्य इफ़े यदि अनुक्रम में दिखाई देता है।

ẆÇÐfQL - Main link: string
Ẇ      - all non-empty contiguous sublists
  Ðf   - filter keep if...
 Ç     -     last link (2) as a monad ...is truthy
    Q  - unique results
     L - length

O_48«26%⁴µSeÇ - Link 2, isBlackjackSubtring: char array  e.g. ['A','2','8','Q']
O             - cast to ordinal values                        [ 65, 50, 56, 81]
 _48          - subtract 48                                   [ 17,  2,  8, 33]
     26       - 26
    «         - minimum (vectorises)                          [ 17,  2,  8, 26]
        ⁴     - 16
       %      - modulo                                        [  1,  2,  8, 10]
         µ    - monadic chain separation (call the result v)
          S   - sum(v)                                        21
            Ç - last link (1) as a monad link_1(v)            [11,21]
           e  - exists in?                                    1

1e×5,⁵Ḥ‘ - Link 1 validSums: value list (where A is 1, and {T,J,Q,K} are 10)
1e       - 1 exists in? (are there any aces? Yields 1 or 0)
  ×5     - multiply by 5 (5 or 0)
     ⁵   - 10
    ,    - pair ([5,10] or [0,10])
      Ḥ  - double ([10,20] or [0,20])
       ‘ - increment ([11,21] or [1,21])
         -                        ^
         -     note: if no ace is in the sequence it's sum can't be 1 anyway

7

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

def b(s,a=[],r=range):
 S=map(lambda x:":">x>"1"and int(x)or 10-(x=="A")*9,s)
 for i in r(12):
  for j in r(13):
   if 21in[x*10+sum(S[i:j])for x in r(S[i:j].count(1)+1)]and s[i:j]not in a:a+=s[i:j],
 return len(a)

टिप्पणियाँ गयीं:

def b(s,a=[],r=range):                                      # Define the function b and a list, a, which holds all the blackjack sequences
 S=map(lambda x:":">x>"1"and int(x)or 10-(x=="A")*9,s)      # Set S to the score of each card in b
 for i in r(12):                                            # Loop with i from 0 to 11
  for j in r(13):                                           # Loop with j from 0 to 12
   if 21in[x*10+sum(S[i:j])for x in r(S[i:j].count(1)+1)]\  # If 21 is included in all the possible sums that the scores between i and j in S can be
           and s[i:j]not in a:                              # And that sequence is not already included,
               a+=s[i:j],                                   # Append that sequence to a
 return len(a)                                              # Return the amount of elements in a

3

पायथन , 134 130 बाइट्स

lambda x:len({x[i:j]for i in range(12)for j in range(13)if sum(min(26,ord(c)-48)%16for c in x[i:j])in([11,21][~('A'in x[i:j]):])})

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

कैसे?

एक अनाम फ़ंक्शन, लंबाई की स्ट्रिंग 12 के रूप में ले रही है x

x[i:j]i + 1 वें से j वें वर्ण तक स्ट्रिंग का एक टुकड़ा है ।

स्लाइस इस तरह लिया जाता है हम से traversing द्वारा सभी उप-सूचियों है कि i=0करने के लिए i=11के साथ for i in range(12), जिनमें से प्रत्येक हम से पार के लिए j=0करने के लिए j=12के साथ for j in range(13)

(हम केवल जरूरत है j=i+1और ऊपर है, लेकिन साथ स्लाइस j<=iसिर्फ खाली तार हैं, इसलिए हम 4 बाइट को बंद कर सकते हैं for j in range(i+1,13))

ये सही राशि वाले लोगों के लिए फ़िल्टर किए गए हैं ...

यदि एक स्लाइस में इक्का है, या नहीं तो केवल 21 और 11 वैध हैं। 'A'in x[i:j]हमें यह जानकारी देता है और ~(v)प्रदर्शन करता है -1-v, जिसका उपयोग हम स्लाइस के लिए करते हैं [11,21]- इस प्रकार यदि कोई इक्का उस क्रम में है जो हमें मिलता है [11,21][-2:]और यदि नहीं मिलता है [11,21][-1:], जिसके परिणामस्वरूप [11,21]और [21]क्रमशः।

योग से ही इलाज की जरूरत है A1 के रूप में, उनके मूल्यों के रूप में अंक, और T, J, Q, और K10 के रूप में यह मानचित्रण पहले कास्टिंग द्वारा ऑर्डिनल्स लिए हासिल की है:
" 2 3 4 5 6 7 8 9 T J Q K A"(रिक्तियों के बिना) हो जाता है
[50, 51, 52, 53, 54, 55, 56, 57, 84, 74, 81, 75, 65], 48 को घटाकर प्राप्त करने के लिए
[ 2, 3, 4, 5, 6, 7, 8, 9, 36, 26, 33, 27, 17], ले रही min26 पैदावार के साथ
[ 2, 3, 4, 5, 6, 7, 8, 9, 26, 26, 26, 26, 17], और आधुनिक ( %) सोलह वे हैं
[ 2, 3, 4, 5, 6, 7, 8, 9, 10, 10, 10, 10, 1], जैसे योग के लिए आवश्यक हैं sum(...)

फ़िल्टर किए गए परिणाम के साथ एक सेट में जगह है {...}, इसलिए केवल अद्वितीय परिणाम रहते हैं और लंबाई, len(...)गिनती है


3

05AB1E , 39 38 37 बाइट्स

'A1:vTy‚ydè})ŒvyO¸y1åiDT+ì}21å})¹ŒÏÙg

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

व्याख्या

'A1:                  # replace A with 1 in input

v      }              # for each card
 Ty‚                  # pair 10 and the card
    yd                # check if the card is a digit
      è               # use this to index into the pair, giving 10 for JQK
        )             # wrap in list
                      # we now have a list of cards as numbers in range [1 ... 10]

Œv               }    # for each sublist
  yO¸                 # create a list with the sum of the sublist
     y1åi    }        # if the sublist contain 1
         DT+ì         # add sum+10 to the list
              21å     # check if 21 is in that list
                  )   # wrap in list
                      # we now have a list with 1 where the sublist sums to 21 and
                      # 0 otherwise

¹Œ                    # get sublists of the input
  Ï                   # keep only those which sum to 21
   Ù                  # remove duplicates
    g                 # count the number of lists

3

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

f=
t=>eval("for(s=new Set,i=0;t[i];i++)for(a=0,b=21,j=i;c=t[j++];b&&b-a*10||s.add(t.slice(i,j)))b-=+c||(c>'A'?10:a=1);s.size")
<input oninput=o.textContent=/[^2-9TJQKA]/.test(this.value)?'':f(this.value)><pre id=o>


महान विचार है, लेकिन यह बदले 0के AAAAAAAAAAAAबजाय लौटता है 1। ( Aएक साथ 1 और 11 हो सकते हैं)
ETHproductions

हमारी दो प्रविष्टियों को मिलाकर आप s=>eval("q=new Set;for(i=0;s[i];i++)for(t=A=0,j=i;c=s[j++];t==21|t==11&A&&q.add(s.slice(i,j)))t+=+c||(c<'B'?A=1:10);q.size")124 बाइट्स के लिए प्राप्त कर सकते हैं
ETHproductions

@ETHproductions 21 से शुरू होकर अभी भी मुझे एक बाइट बचाने के लिए लगता है।
नील

@ETHproductions ... यह मदद करता है अगर मैं सही बाइट गिनती पोस्ट करता हूं ...
नील

3

जावास्क्रिप्ट (ईएस 6), 144 138 129 128 126 124 बाइट्स

g=([c,...s],a=[],q=new Set)=>c?g(s,[...a,[,21]].map(([x,y,A])=>[x+=c,y-=+c||(c<'B'?A=1:10),A,y&&y^10*A||q.add(x)]),q):q.size

128 पर पुराना प्रयास:

s=>(q=new Set,f=s=>s?f(s.slice(1))&f(s.slice(0,-1))&[...s].map(c=>t+=-c||~(c<'B'?A=0:9),t=A=21)|t&&t-10*!A?q:q.add(s):q)(s).size

s.search`A`>-1हो सकता है~s.search`A`
ल्यूक

@Luke नहीं, वास्तव में, क्योंकि यह मानों को लौटाता है -2, और जैसे1&-2 == 0
ETHproductions

सच। शायद कॉल में सेट tहै (2 बी बचाता है)? 0.slice(0,-1)
ल्यूक

@ मुझे लगता है कि यह काम नहीं करेगा, जैसा tकि एक वैश्विक चर है और इसे कॉल के कारण रीसेट किया जाएगा f(s.slice(0,-1))। लेकिन मुझे एक रास्ता मिल गया s.search`A`>-1:-)
ETHproductions

मैं यह देखने के लिए उत्सुक हूं कि जब आपके पास यह काम हो रहा है तो आप क्या करेंगे। मुझे लगता है कि यह अब 113 पर अटक जाएगा।
अरनौलद

3

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

f=(s,x=[k=0])=>s?f(s.slice(1),x,[...s].map(c=>x[t+=+c||10^(c<'B'?a=11:0),b+=c]||t-21&&t-a?0:x[b]=++k,a=b=t=0)):k

यह कोड लॉजिक ETHproductions और नील के मौजूदा JS उत्तरों में उपयोग किए जाने वाले समान है । लेकिन यह एक मूल सरणी का उपयोग कर रहा है बजाय एक का सामना करना पड़ा ब्लैकजैक दृश्यों का ट्रैक रखने के लिए Set

प्रारूपित और टिप्पणी की गई

f = (                     // given:
  s,                      //  - s = list of cards
  x = [k = 0]             //  - x = array of Blackjack sequences
) =>                      //  - k = number of distinct Blackjack sequences 
  s ?                     // if s is not empty:
    f(                    //   do a recursive call:
      s.slice(1),         //     starting at the next card in the list
      x,                  //     without re-initializing x[]
      [...s].map(         //   for each card 'c' in the list:
        c => x[           //
          t+ =            //   update the total number of points:
            +c ||         //     using the number of the card (for 2 ... 9)
            10 ^ (        //     or using 10 for all other cards
              c < 'B' ?   //     except the Ace which is
                a = 11    //     counted as 1 point and sets 'a' to 11
              :           //     (which means that a total number of points
                0         //     of 11 will be considered valid from now on)
            ),            //
          b += c          //   update the current sequence 'b'
        ] ||              //   if x[b] was previously stored as a Blackjack sequence
        t - 21 &&         //   or the total number of points is not equal to 21
        t - a ?           //   and not equal to 'a':
          0               //     do nothing
        :                 //   else:
          x[b] = ++k,     //     store the current sequence in x[] and increment k
        a = b = t = 0     //   initialization of all variables used in map()
      )                   //
    )                     //
  :                       // else:
    k                     //   return k

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


मैंने दोहरे पुनरावृत्ति की कोशिश की, स्ट्रिंग के माध्यम से पीछे की ओर बढ़ते हुए, प्रत्येक चरित्र का उपभोग करते हुए प्रत्येक संभावित स्ट्रिंग की गणना करते हुए ... और फिर भी सबसे छोटा दृष्टिकोण प्रत्येक स्लाइस के माध्यम से चलना है। अच्छा है! (एक सेट का उपयोग करना तीन बाइट्स से अधिक लंबा प्रतीत होता है, अगर मैंने सही तरीके से गणना की हो)
ETHproductions

2

05AB1E , 40 39 38 37 36 बाइट्स

-4 एमीना को धन्यवाद

Ç<çJŒÙ'@0:[Ž„èµJuS9:S>D1å2‚T*>sOå½]¾

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

Ç<ç                                  # decrement characters by 1
   JŒÙ                               # get all unique substrings
      '@0:                           # replace @ (was A) with 0
          [Ž                      ]  # for everything on the stack
            „èµJuS9:                 # replace what was T,J,Q,K with 9
                    S>D              # increment all values
                       1å2‚T*>       # push [11,21] if there was an A, [1,21] otherwise
                              sO     # sum the values of the cards
                                å½   # increment the counter_variable if the sum 
                                     # is in the array
                                   ¾ # end loop and push (print) the counter_variable

हमें डिक्रीमेंट -> सबस्ट्रिंग -> इंक्रीमेंट चीज़ करने की ज़रूरत है ताकि फेस कार्ड्स को सिंगल डिजिट नंबर द्वारा दर्शाया जाए।


डबल अंकों के आसपास होने का अच्छा तरीका! आप पहले Sको हटा सकते हैं जैसा Çकि स्ट्रिंग को वर्ण कोड की सूची में बदल देता है।
एमिगा

इसके अलावा, "SIPJ"हो सकता है„èµJu
Emigna

@Emigna धन्यवाद मैंने सोचा था कि ऐसा करने का एक तरीका है, लेकिन मुझे पता नहीं चल सका कि दस्तावेज में कैसे उपयोग किया जाए।
रिले

आप इसे Ç<çJŒÙ'@0:)vy„èµJuS9:S>D1å2‚T*>sOå}Oफिर से लिखने से 2 और बाइट्स बचा सकते हैं क्योंकि आप मेरे जवाब से 1 बाइट छोटी हैं :)
एमिगा

@Emigna यह वही बाइट काउंट है और मेरे मूल के समान है।
रिले

1

बैश + यूनिक्स उपयोगिताओं, 145 142 141 बाइट्स

for n in {9..155}
{ echo ${1:n%12:n/12};}|sort -u|sed 's/\(.\)/+\1/g;s/A/{1,11}/g;s/[J-T]/10/g;s/^/eval echo $[0/;s/$/]/'|sh|grep -c '\<21\>'

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

टेस्ट रन:

for x in 3282486Q3362 58A24JJ6TK67 Q745Q745Q745 AAAAAAAAAAAA T5AQ26T39QK6 JQ4A4427464K Q74Q74Q74Q74 37AQKA3A4758 TAQA2JA7AJQA TAJAQAKAT777
  do
    echo -n "$x "
    ./21 "$x"
  done

3282486Q3362 0
58A24JJ6TK67 1
Q745Q745Q745 1
AAAAAAAAAAAA 1
T5AQ26T39QK6 2
JQ4A4427464K 3
Q74Q74Q74Q74 3
37AQKA3A4758 7
TAQA2JA7AJQA 10
TAJAQAKAT777 13

1

PHP, 240 बाइट्स

$a=str_split($argv[1]);foreach($a as$k=>$v)$n[$k]=$v=='A'?1:($v==0?10:$v);for($i=0;$i<=$k;$i++){$s=$a[$i];$r=$n[$i];for($j=$i+1;$j<=$k;$j++){$s.=$a[$j];$r+=$n[$j];if ($r==21||($r==11&&stristr($s,'A')))$f[]=$s;}}echo count(array_unique($f));

अधूरा:

$a = str_split($argv[1]);
foreach ($a as $k=>$v)
    $n[$k] = $v == 'A' ? 1 : ($v == 0 ? 10 : $v);
for ($i=0; $i<=$k; $i++) {
    $s = $a[$i];
    $r = $n[$i];
    for ($j=$i+1; $j<=$k; $j++) {
        $s .= $a[$j];
        $r += $n[$j];
        if ($r == 21 || ($r == 11 && stristr($s,'A')) )
            $f[] = $s;
    }
}
echo count(array_unique($f));

यहाँ कोशिश करो!


1
अजीब, मैं इसे अपने स्थानीय परीक्षणों पर काम कर सकता था, लेकिन ऐसा लगता है कि आप सही हैं। वैसे भी, समस्या इस तथ्य से आई $iथी जिसे घोषित नहीं किया गया था। 4 बाइट्स जोड़े गए और यह पूरी तरह से काम करता है।
roberto06
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.