एकल-अनुकूल माहजोंग के लिए हाथ के मूल्यों की जाँच करें


12

महजोंग एक टाइल गेम है जो एशिया में बेहद लोकप्रिय है। यह आमतौर पर चार खिलाड़ियों के साथ खेला जाता है, और खेल का लक्ष्य टाइल्स का उपयोग करके वैध हाथ पूरा करने वाला पहला व्यक्ति होना है। महाजोंग में तीन टाइल सूट प्लस ऑनर टाइल हैं - इस चुनौती के लिए हम केवल सिंगल सूट से टाइल्स का उपयोग करके गठित हाथों पर विचार करेंगे।

टाइल्स से 1लेकर तक की संख्या है 9, और प्रत्येक टाइल की बिल्कुल चार प्रतियां हैं। एक वैध हाथ में कुल चौदह टाइल्स के लिए तीन और एक जोड़ी के चार सेट होते हैं।

तीन का एक सेट या तो हो सकता है:

  • एक ट्रिपल, एक ही टाइल के तीन (जैसे 444), या
  • तीन लगातार टाइलों का एक क्रम (उदाहरण के लिए 123या 678नहीं 357)। अनुक्रम लपेटता नहीं है (इसलिए 912अमान्य है)।

एक जोड़ी बस दो समान टाइल (जैसे 55) है।

चुनौती

चौदह टाइलों के एक वैध हाथ को देखते हुए, निम्न मानदंडों के आधार पर इसका स्कोर निर्धारित करें:

Condition                Description                                 Point/s
-------------------------------------------------------------------------------
Straight                 Contains the sequences 123 456 789          1
Identical sequences      Contains two identical sequences            1
All simples              Only 2-8, no 1s or 9s                       1
All sequences            All sets of three are sequences             1
All triplets             All sets of three are triplets              2
Flush                    Single-suit hand (always applies)           5

(यहां स्कोरिंग जापानी माहजोंग नियमों पर आधारित है, लेकिन कल्पना को कम गन्दा बनाने के लिए बहुत सरल बनाया गया है।)

एक हाथ का स्कोर उन स्थितियों के लिए बिंदुओं का योग है जो इसे संतुष्ट करता है। यदि एक हाथ को एक से अधिक तरीकों से विघटित किया जा सकता है, तो उच्चतम स्कोरिंग अपघटन करें।

इनपुट हाथ वैध होने की गारंटी है, अर्थात 1 से 9 तक चौदह टाइलें और प्रत्येक टाइल सबसे अधिक चार बार दिखाई देती है, और माना जा सकता है कि पहले से ही छंटनी की जा सकती है। इनपुट STDIN, फ़ंक्शन तर्क या कमांड लाइन के माध्यम से अंकों की एक सूची (एक स्ट्रिंग या पूर्णांकों की एक फ्लैट सूची के रूप में) है। आउटपुट STDOUT या वापसी मान हो सकता है।

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

22233355777888  ->  8  # 222 333 55 777 888, flush + all simp. + all trip.
11112345678999  ->  6  # 111 123 456 789 99, flush + straight
11123456788999  ->  5  # 111 234 567 88 999, flush only (no straight)
23344455566788  ->  7  # 234 345 456 567 88, flush + all simp. + all seq.
33334444555566  ->  8  # 33 345 345 456 456, flush + all simp. + all seq. + identical seq.
11122233377799  ->  7  # 111 222 333 777 99, flush + all trip. (no identical seq.)
12344556678889  ->  8  # 123 456 456 789 88, flush + all seq. + straight + identical seq.
11344556678999  ->  5  # 11 345 456 678 999, flush only (no identical seq.)
22233344455566  ->  8  # 222 333 444 555 66, flush + all simp. + all trip.
11112233344555  ->  5  # 111 123 234 345 55, flush only

पांचवें उदाहरण के लिए, समान अनुक्रमों के दो जोड़े होने के बावजूद, बिंदु को प्राप्त करने के लिए केवल एक को प्रस्तुत करने की आवश्यकता है। अपघटन 345 345 345 345 66समान होगा, जबकि 333 345 444 555 66स्कोर बदतर होगा।

स्कोरिंग

यह , इसलिए सबसे कम बाइट्स में समाधान जीतता है। मानक खामियां लागू होती हैं।


संबंधित चुनौती: आप किसकी प्रतीक्षा कर रहे हैं? (एक माहजोंग सॉल्वर)

जवाबों:


1

जे (241 बाईस)

आपको J का नवीनतम संस्करण स्थापित करना होगा।

i=:>:@i.9
q=:,/^:4>@:{(i.9);(i.;i.;i.;i.)16
s=:3 :'(>./((5+([:(*./)(3*i.3)&e.)+(-.@:(-:~.))+((*./)@:(6&>:))+2*((*./)@:(6&<)))"1(}."1(y(-:/:~"1)"1((([:{&(i,.i){.),[:,/[:{&(((>:@i.7)+"0 1(i.3)),|:3 9$i)}.)"1 q))#q)))+([:(*./)[:-.((1 9)&e.))y'

sपूर्णांक की सूची के साथ फ़ंक्शन को कॉल करें । उदाहरण के लिए, निम्नलिखित उदाहरण स्क्रिप्ट उपरोक्त परीक्षण मामलों की पुष्टि करता है:

#!/usr/bin/jconsole
i=:>:@i.9
q=:,/^:4>@:{(i.9);(i.;i.;i.;i.)16
s=:3 :'(>./((5+([:(*./)(3*i.3)&e.)+(-.@:(-:~.))+((*./)@:(6&>:))+2*((*./)@:(6&<)))"1(}."1(y(-:/:~"1)"1((([:{&(i,.i){.),[:,/[:{&(((>:@i.7)+"0 1(i.3)),|:3 9$i)}.)"1 q))#q)))+([:(*./)[:-.((1 9)&e.))y'


echo (s 2 2 2 3 3 3 5 5 7 7 7 8 8 8)=8
echo (s 1 1 1 1 2 3 4 5 6 7 8 9 9 9)=6
echo (s 1 1 1 2 3 4 5 6 7 8 8 9 9 9)=5
echo (s 2 3 3 4 4 4 5 5 5 6 6 7 8 8)=7
echo (s 3 3 3 3 4 4 4 4 5 5 5 5 6 6)=8
echo (s 1 1 1 2 2 2 3 3 3 7 7 7 9 9)=7
echo (s 1 2 3 4 4 5 5 6 6 7 8 8 8 9)=8
echo (s 1 1 3 4 4 5 5 6 6 7 8 9 9 9)=5
echo (s 2 2 2 3 3 3 4 4 4 5 5 5 6 6)=8
echo (s 1 1 1 1 2 2 3 3 3 4 4 5 5 5)=5

exit''
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.