Nazwij rękę pokera

22

Nazwij rękę pokera

Biorąc pod uwagę pięć kart, wypisz nazwę ręki pokera, która będzie jedną z:

High card
One pair
Two pair
Three of a kind
Straight
Flush
Full house
Four of a kind
Straight flush
Royal Flush

W razie wątpliwości zapoznaj się z zasadami na stronie http://en.wikipedia.org/wiki/List_of_poker_hands .

Wkład

5 kart z argumentów standardowego lub wiersza poleceń. Karta to dwuliterowy ciąg znaków w formularzu RS, w którym R jest rangą, a S - kolorem. W szeregi2- 9(karty), numer T(dziesięć), J(Jack), Q(Queen), K(King), A(ACE). Te strojeS, D, H, Cdla pik, karo, kier i klubów odpowiednio.

Przykład kart

5H - five of hearts
TS - ten of spades
AD - ace of diamonds

Przykład wejścia => pożądany wynik

3H 5D JS 3C 7C => One pair
JH 4C 2C JD 2H => Two pair
7H 3S 7S 7D 7C => Four of a kind
8C 3H 8S 8H 3S => Full house

Zasady

Najkrótszy kod wygrywa

Edytować

Jak dotąd świetnie wygląda! Naprawdę nie mogę zweryfikować wszystkich odpowiedzi, ponieważ nie znam tych języków zbyt dobrze i nie mam kompilatorów / tłumaczy dla wszystkich, ale podejrzewam, że nie wszyscy myśleli o tym, że Asy mogą być zarówno najwyższe, jak i najniższe karty strita (kolor) .

daniero
źródło
2
Na przepełnieniu stosu jest niejasno powiązana staruszka .
dmckee
Czy wolno nam pisać wielkie litery (lub nie) według własnych upodobań?
Mr.Wizard
Mr.Wizard, jasne.
daniero

Odpowiedzi:

3

GolfScript ( 209 208 207 206 200 199 197 196 znaków)

3/zip:^0={10,''*"TJQKA"+?}/]:?15,{?\{=}+,,}%2,-$6,14.),++@$/):|;[!!2*^1=.&,(!+5+]or{/}*'Full house
Two pair
One pair
ThreeKFourKHigh card
Flush
Straight''K'/' of a kind
'*n/~|1$"Royal"if" "+2$+](=

Korzystam z oferowanej swobody modyfikowania wielkich liter: mój Straight Flush i Royal Flush kapitalizują Flush, aby ponownie użyć słowa z prostego koloru.

Uwaga: niektóre wcześniejsze wersje były błędne: wspierały full house tylko wtedy, gdy para miała niższą wartość niż para royal. Można je poprawić, zastępując spację oddzielającą - 0$.

Próbny

Peter Taylor
źródło
To jest program w golfa! Szukałem sposobów na skrócenie tego, ale nic nie mogę wymyślić. Używanie .&do znajdowania różnych znaków w ciągu jest bardzo przydatną sztuczką.
Cristian Lupascu,
@ w0lf, to dość standardowa sztuczka. Howard używa go również w swoim rozwiązaniu.
Peter Taylor,
8

Przyszedł z własną odpowiedzią :)

Python - 312 301 298

R,K,F,S,g=' 23456789TJQKA2345A',' of a Kind','Flush','Straight ',sorted
s,r=''.join(g(raw_input(),key=R.find)).split()
n,m=g(map(r.count,set(r)))[-2:]
print[[F,[0,'High Card','TOwnoe'[n&1::2]+' Pair',['Full House','Three'+K][n&1],'Four'+K][m]],[[S,'Royal '][r[0]=='T']+F,S]][r in R][len(set(s))>1]

Tworzy listę 2x2, w której indeksy dwóch wymiarów są wartościami logicznymi dla koloru i koloru prostego. W przypadku obu sprawdzamy, czy jest to poker królewski, czy tylko strit. Aby nie mieć koloru ani pokera, sprawdzamy inne układy: mi nprzechowujemy najwyższą i drugą najwyższą liczbę kart o tej samej wartości; nazwy rąk są przechowywane na liście z indeksami według m. Kontrole cząstkowe w ramach wartości tej listy są przeprowadzane w ncelu oddzielenia jednej pary z dwóch par i trzech z domu.

Edycja: Dzięki Nolen Royality za zapisanie łącznie 20 znaków!

daniero
źródło
1
... i pokonaj moje.
Mr.Wizard
Uwielbiam nowe rozwiązanie, 312 znaków jest dość małe. Bardzo sprytna metoda radzenia sobie z parami jeden na dwóch: D
Nolen Royalty
Dzięki :) Możesz spróbować, jeśli chcesz. Ale być może nie używasz żadnej podobnej zmiennej jak moja min. Sprawdzając to i ponownie oglądając Twój kod, właśnie zdałem sobie sprawę, że mogę trochę się ogolić na oryginalnym ^^
daniero
1
Czy nie możesz stracić kolejnych 8 znaków, przechodząc m,n=g([c.count(x)for x in set(r)])na m,n=g(map(c.count,set(r)))?
Nolen Royalty
Woah, masz rację, mógłbym: D Nie wiem, dlaczego wpadło mi to w pamięć. Dobry chwyt, dzięki!
daniero
5

Ruby 1.9 (427 359 348 338 296 292)

EDYCJA : Naprawiono do pracy z niskimi asami.

o,p=%w(flush straight)
f=/1{5}|1{4}0+1$/
s=[0]*13
puts Hash[*$*.map{|c|s['23456789TJQKA'.index c[0]]+=1;c[1]}.uniq[1]?[f,p,?4,'four'+a=' of a kind',/3.*2|2.*3/,'full house',?3,'three'+a,/2.*2/,'two pair',?2,'one pair',0,'high card']:[/1{5}$/,'royal '+o,f,p+' '+o,0,o]].find{|r,y|s.join[r]}[1]

Podstawową ideą jest zbudowanie tablicy ilości kart w każdej randze, połączenie cyfr w ciąg znaków, a następnie uruchomienie wyrażeń regularnych, aby sprawdzić, który kształt pasuje. Bieżemy liczbę różnych kolorów, aby ustalić, czy sprawdzić to z różnymi kolorami (kolor, kolor prosty, kolor królewski) lub z innymi kształtami (wszystko inne).

Bierze karty jako osobne argumenty wiersza poleceń, takie jak:

>ruby poker-hand-golf.rb 3H 5D JS 3C 7C
one pair
Paul Prestidge
źródło
4

C, 454 znaków

#define L for(a=1;a<6;a++)for(b=0;b<13;b++)
#define U u[b+6]
#define R(x,y) if(x)puts(#y);else
b,f,r,h=0,s=0,u[20]={0};main(int a,char**v){L U+=v[a][0]=="23456789TJQKA"[b];f=v[1][1];L{if(v[a][1]!=f)f=0;u[a]+=a==U;if(b>7)h+=U;if(a*13+b<64||!U)r=0;else if(++r==5)s=1;}R(f&&h==25,Royal flush)R(f&&s,Straight flush)R(u[4],Four of a kind)R(u[3]&&u[2],Full house)R(f,Flush)R(s,Straight)R(u[3],Three of a kind)R(u[2]==2,Two pair)R(u[2],One pair)R(h,High card);}

Uruchom z wiersza poleceń z kartami jako argumentami, np ./a.out 8C 3H 8S 8H 3S

Wersja rozszerzona z komentarzami:

#define L for(a=1;a<6;a++)for(b=0;b<13;b++)
#define R(x,y) if(x)puts(#y);else
#define U u[b+6]
b,f,r,h=0,s=0,u[20]={0};
main(int a,char**v){
    // card usage - u[6..]
    L U+=v[a][0]=="23456789TJQKA"[b];
    // NOTE: lets expand the inner body of the loop in the answer so this looks more sane:
    // flush
    f=v[1][1];L if(v[a][1]!=f)f=0;
    // count of usages - u[0..5] 
    L u[a]+=a==U;
    // high cards x5
    L if(b>7)h+=U;
    // straights
    L if(a*13+b<64||!U)r=0;else if(++r==5)s=1;        
    // display
    R(f&&h==25,Royal flush)
    R(f&&s,Straight flush)
    R(u[4],Four of a kind)
    R(u[3]&&u[2],Full house)
    R(f,Flush)
    R(s,Straight)
    R(u[3],Three of a kind)
    R(u[2]==2,Two pair)
    R(u[2],One pair)
    R(h,High card);    
}

Edycje:

  1. Zapisano 12 znaków, łącząc i ponownie wykorzystując pętle.
  2. Zapisano 9 znaków, wprowadzając stałą ciągu.
  3. Zaoszczędzono 19 znaków przy użyciu strunizacji w makrze, nieprzyjemne ..
króliczek
źródło
3

Mathematica , 365

Oto moje zdanie na temat odpowiedzi Davida Carrahera.

Pokazane z białą przestrzenią dla pewnej czytelności.

If[
  a = Characters;
  x = Thread;
  r = Range;
  d = Sort[a@StringSplit@# /. x[a@"23456789TJQKA" -> 2~r~14]];
  {t, u} = Sort[Last /@ Tally@#] & /@ x@d;
  c = First /@ d;
  f = u == {5};
  S = "Straight";
  c == r[b = d[[1, 1]], b + 4],
  If[f,
   If[c == 10~r~14, "Royal Flush", S <> " flush"], S],
  If[f, "Flush",
   Switch[t,
    {_, 4},    "Four of a kind",
    {2, 3},    "Full house",
    {__, 3},   "Three of a kind",
    {_, 2, 2}, "Two pair",
    {__, 2},   "One pair",
    _,         "High card"]
  ]
] &

Wersja jednoliniowa:

If[a=Characters;x=Thread;r=Range;d=Sort[a@StringSplit@#/.x[a@"23456789TJQKA"->2~r~14]];{t,u}=Sort[Last/@Tally@#]&/@x@d;c=First/@d;f=u=={5};S="Straight";c==r[b=d[[1,1]],b+4],If[f,If[c==10~r~14,"Royal Flush",S<>" flush"],S],If[f,"Flush",Switch[t,{_,4},"Four of a kind",{2,3},"Full house",{__,3},"Three of a kind",{_,2,2},"Two pair",{__,2},"One pair",_,"High card"]]]&
Mr.Wizard
źródło
Miły. Znalazłeś nawet miejsce do zaoszczędzenia dzięki dopasowaniu wzorca. Np. _Zamiast{_,_,_,_}
DavidC
Ładne rozwiązania, oboje. Ze względu na liczbę znaków uważam, że „Para” powinna nosić nazwę „Jedna para”, chociaż brzmi to trochę źle, ponieważ to właśnie opublikowałem, a inne zaimplementowałem.
daniero
@Daniero Thanks. Naprawię imię.
Mr.Wizard
3

K, 294 295

d:{F:"Flush";S:"Straight ";P:" Pair";K:" of a kind";$[(f:1=#?,/-1#'c)&("AJKQT")~a@<a:,/j:1#'c:" "\:x;"Royal ",F;f&s:(4#1)~1_-':a@<a:,/(("A23456789TJQKA")!1+!14)@j;S,F;4=p:|/#:'=j;"Four",K;(2;3)~u:a@<a:,/#:'=j;"Full House";f;F;s;S;3=p;"Three",K;(1;2;2)~u;"Two",P;(1;1;1;2)~u;"One",P;"High Card"]}

.

k)d'("TS JS QS KS AS";"3S 4S 5S 7S 6S";"JC JH KS JD JS";"JC JH 2S JD 2C";"2C 9C TC QC 6C";"8C 5D 9H 6C 7D";"8C 8D 9H 8S 7D";"8C 8D 9H 2S 9D";"8C 8D 4H 2S 9D";"3C 8D 4H 2S 9D")
"Royal Flush"
"Straight Flush"
"Four of a kind"
"Full House"
"Flush"
"Straight "
"Three of a kind"
"Two Pair"
"One Pair"
"High Card"

edycja: Dodano 1 znak dla niskich asów

tartin
źródło
3

Python 334 , 326 322 Znaki

p,f,l,t,o=" pair"," of a kind"," Flush","Straight","A23456789TJQK"
v,u=zip(*raw_input().split())
s=''.join(sorted(v,key=o.find))
print{5:"High card",7:"One"+p,9:"Two"+p,11:"Three"+f,13:"Full house",17:"Four"+f,23:t,24:l[1:],25:t,42:t+l,44:"Royal"+l}[(sum(map(v.count,v)),24)[len(set(u))<2]+((0,20)[s=="ATJQK"],18)[s in o]]

Wiem, że ostatnia linijka staje się dość nieczytelna, gdy będę zadowolony z mojego rozwiązania, założę wersję bez gry w golfa.

Nolen Royalty
źródło
2

GolfScript, 258 250 znaków

3/zip~;.&,(!\{"23456789TJQKA"?}%$.(\{.@- 8%}%\;"\1"-!\.1/.&{1$\-,}%1.$?)"Four"" of a kind":k+{.,2="Full house"{.2\?)"Three"k+{.3-,({.3\?)"One pair"{;"Straight":?;2$2$&{(8="Royal"?if" flush"+}{;?{"Flush""High card"if}if}if}if}"Two pair"if}if}if}if])\;

Program oczekuje wejścia na STDIN, jak podano powyżej, i wyjścia na STDOUT. Możesz sam przetestować kod .

> 8C 3H 8S 8H 3S
Full house

> 8C 7H 6S TH 9S
Straight

> AH 3H 4S 2H 6S
High card

Edycja: uwzględniono sugestie w0lf.

Howard
źródło
Fajne rozwiązanie! Możesz zapisać 3 znaki, wstawiając " of a kind"zmienną, ponieważ jest ona używana dwukrotnie.
Cristian Lupascu,
współpracuje również z"Straight"
Cristianem Lupascu,
@ w0lf Dziękujemy. Dodałem twoje sugestie do kodu.
Howard
Wydaje mi się, że w wykrywaniu prostych występuje subtelny błąd: AH KH 2C 3H 4Hjest uważany za prosty, ale powinien mieć wysoką kartę.
Cristian Lupascu,
@ w0lf Hmmm, muszę o tym pomyśleć ...
Howard
2

Mathematica - 500 494 465 znaków

To rozwiązanie jest oparte na pokerze demonstrowanej przez Eda Pegga, Jr. W tej wersji karty są traktowane wewnętrznie jak liczbyRange[2,14]

v[x_] := Block[{d, t, c, f, s},
 d = Sort@ToExpression[Characters[ImportString[x, "Table"][[1]]] /. {"T" -> 10, "J" -> 11, "Q" -> 12, "K" -> 13, "A" -> 14}];t = Sort /@ Map[Length, Split /@ Sort /@ Transpose@d, {2}];c = d[[All, 1]];f = (t[[2]] == {5});s = c == Range[b = d[[1, 1]], b + 4];
If[s,
 If[f, If[c == 10~Range~14, "royal flush", "straight flush"],"straight"],
 If[ f, "flush",
Switch[t[[1]],
 {1, 4}, "four of a kind",
 {2, 3}, "full house",
 {1, 1, 3}, "three of a kind",
 {1, 2, 2}, "two pair",
 {1, 1, 1, 2}, "one pair",
 {1, 1, 1, 1, 1}, "high card"]]]]

Przykładowe wejścia, wyjścia:

dane

Uwagi:

f: kolor

c: karty (bez koloru)

s: prosty

t: {karty, apartamenty}

re:

DavidC
źródło
Fajnie, ale jak uzyskać dwie pary JH 4C 2C JD TH ?
daniero
Masz rację. Wystąpił błąd, gdy połączyłem niektóre komponenty razem w czystą funkcję. Wyśledzę to.
DavidC
@Daniero Poruszony problem został rozwiązany.
DavidC
David, jest dużo miejsca na skompresowanie tego. Czy mogę?
Mr.Wizard
@ Mr.Wizard Bądź moim gościem. Będę oglądać i uczyć się.
DavidC