Dai un nome alla mano di poker


22

Dai un nome alla mano di poker

Date cinque carte, ottieni il nome della mano di poker, che sarà una delle seguenti:

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

In caso di dubbi, consultare le regole su http://en.wikipedia.org/wiki/List_of_poker_hands .

Ingresso

5 carte da argomenti stdin o commandline. Una carta è una stringa di due lettere sul modulo RS, dove R è il rango e S è il seme. I gradi sono 2- 9(carte numeriche), T(dieci), J(Jack), Q(regina), K(re), A(asso). Gli abiti sono S, D, H, Cper picche, quadri, cuori e club rispettivamente.

Esempio di carte

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

Esempio di input => output desiderato

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

Regole

Il codice più corto vince

modificare

Finora fantastico! Non riesco davvero a verificare tutte le risposte, dal momento che non conosco molto bene queste lingue e non ho compilatori / interpreti per tutte, ma sospetto che non tutti abbiano pensato che gli assi possano essere sia i più alti che le carte più basse di una scala (colore) .


2
C'è un vecchio vagamente imparentato su Stack Overflow .
dmckee,

Siamo autorizzati a scrivere in maiuscolo (o no) i nomi delle mani come preferiamo?
Mr.Wizard il

Mr.Wizard, certo.
daniero,

Risposte:


3

GolfScript ( 209 208 207 206 200 199 197 196 caratteri)

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$+](=

Sto sfruttando la libertà offerta per modificare le maiuscole: il mio Straight Flush e Royal Flush sono entrambi in maiuscolo per riutilizzare la parola dal semplice flush.

Nota: alcune versioni precedenti erano buggy: supportavano full house solo quando la coppia era di valore inferiore rispetto alla coppia royal. Possono essere corretti sostituendo lo spazio che separa - 0con a $.

dimostrazione


Questo è un programma di golf! Ho cercato dei modi per accorciarlo, ma non riesco a trovare nulla. Usare .&per trovare i caratteri distinti in una stringa è un trucco molto utile.
Cristian Lupascu,

@ w0lf, è un trucco abbastanza standard. Anche Howard lo usa nella sua soluzione.
Peter Taylor,

8

È venuto con una mia risposta :)

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]

Crea un elenco 2x2 in cui gli indici delle due dimensioni sono controlli booleani per flush e straight. In entrambi i casi, controlliamo se si tratta di una scala reale o di una scala reale. Per non flush e non straight, controlliamo le altre mani: me ncontiene la quantità più alta e la seconda più alta di carte dello stesso valore; i nomi delle mani sono memorizzati in un elenco con indici secondo m. I sotto-controlli all'interno dei valori di questo elenco vengono eseguiti nper separare una coppia da due coppie e tre di un tipo da casa.

Modifica: Grazie Nolen Royality per un totale di 20 personaggi salvati!


1
... e batti la mia.
Mr.Wizard,

Adoro la nuova soluzione, 312 personaggi è piuttosto piccolo. Metodo molto intelligente per gestire una coppia vs due: D
Nolen Royalty

Grazie :) Se lo desideri, puoi provarlo. Ma forse non stai usando alcuna variabile simile alla mia m e n. Controllando questo e guardando di nuovo il tuo codice, mi sono appena reso conto che posso radere un po 'di più sull'originale ^^
daniero

1
Non potresti perdere altri 8 caratteri passando m,n=g([c.count(x)for x in set(r)])a m,n=g(map(c.count,set(r)))?
Nolen Royalty

Woah, hai davvero ragione: D Non so perché mi sia sfuggito di mente. Buona cattura, grazie!
daniero,

5

Ruby 1.9 (427 359 348 338 296 292)

EDIT : risolto per funzionare con assi bassi.

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]

L'idea di base è quella di costruire un array della quantità di carte in ciascun rango, concatenare le cifre in una stringa e quindi eseguire espressioni regolari per vedere quale forma di mano si adatta. Contiamo il numero di semi distinti per determinare se confrontarlo con i diversi colori (scala, scala reale, scala reale) o con le altre forme (tutto il resto).

Prende le carte come argomenti a riga di comando separati, in questo modo:

>ruby poker-hand-golf.rb 3H 5D JS 3C 7C
one pair

4

C, 454 caratteri

#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);}

Esegui dalla riga di comando con le carte come argomenti, ad es. 8a 3H 8S 8H 3S

Versione estesa, con commenti:

#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);    
}

modifiche:

  1. Hai salvato 12 caratteri combinando e riutilizzando i loop.
  2. Hai salvato 9 caratteri incorporando la costante di stringa.
  3. Hai salvato 19 caratteri usando la stringificazione in macro, cattiva ..

3

Mathematica , 365

Ecco la mia opinione sulla risposta di David Carraher.

Indicato con uno spazio bianco per una certa leggibilità.

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"]
  ]
] &

Versione a una riga:

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"]]]&

Bello. Hai anche trovato spazio da salvare nella corrispondenza del modello. Ad esempio _invece di{_,_,_,_}
DavidC

Belle soluzioni a tutti e due. Per motivi di conteggio dei personaggi, penso che "Pair" dovrebbe essere chiamato "One Pair", anche se suona un po 'male, dato che è quello che ho pubblicato e altri hanno implementato.
daniero,

@Daniero Grazie. Riparerò il nome.
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"

modifica: aggiunto 1 carattere per i rettilinei Ace-low


3

Python 334 , 326 322 personaggi

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]]

So che l'ultimo liner sta diventando illeggibile, metterò su una versione non golfata quando sarò contento della mia soluzione.


2

GolfScript, 258 250 caratteri

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])\;

Il programma prevede input su STDIN come indicato sopra e output su STDOUT. Puoi testare il codice tu stesso .

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

> 8C 7H 6S TH 9S
Straight

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

Modifica: i suggerimenti di w0lf incorporati.


Bella soluzione! Puoi salvare 3 caratteri inserendo " of a kind"una variabile, perché viene usata due volte.
Cristian Lupascu,

funziona anche con"Straight"
Cristian Lupascu il

@ w0lf Grazie. Ho aggiunto i tuoi suggerimenti al codice.
Howard,

Penso che ci sia un bug sottile nel rilevamento di Straights: AH KH 2C 3H 4Hè considerato una scala, ma dovrebbe essere una carta alta.
Cristian Lupascu,

@ w0lf Hmmm, devo pensarci ...
Howard,

2

Mathematica - 500 494 465 caratteri

Questa soluzione si basa su una dimostrazione di poker di Ed Pegg, Jr. In questa versione, le carte sono trattate internamente come numeri inRange[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"]]]]

Ingressi campione, uscite:

dati

Gli appunti:

f: flush

c: carte (senza seme)

s: dritto

t: {carte, suite}

d:


Bello, ma come ne ottieni due coppie JH 4C 2C JD TH?
daniero,

Hai ragione. Si è verificato un errore quando ho unito alcuni componenti in una funzione pura. Lo rintraccio.
DavidC,

@Daniero Il problema che hai sollevato è stato risolto.
DavidC,

David, c'è molto spazio per comprimerlo. Posso io?
Mr.Wizard,

@ Mr.Wizard Diventa mio ospite. Guarderò e imparerò.
DavidC,
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.