js計算德州撲克牌面值的方法
本文實例講述了js計算德州撲克牌面值的方法。分享給大家供大家參考。具體如下:
1. 代碼如下:
this.num = (n % 13) + 2;
this.ch = this.num > 9 ? ("abcdef"[this.num-10]) : this.num;
this.show = "0,1,2,3,4,5,6,7,8,9,10,J,Q,K,A".split(",")[this.num];
this.color = "♠♥♣♦"[n / 13 | 0];
this.toString = function(){
return this.color + this.show;
};
};
var z = function(arg){ //同花順
var a = arg,
t = a[0];
for (var i = 1; i < a.length; i++) {
if( a[i].color === t.color && a[i].num === t.num + 1 ){
t = a[i];
}else if( i === a.length-1 && t.num === 5 && a[i].num === 14 && a[i].color === t.color){
t = a[0];
}else{
return;
}
};
return "z" + t.ch;
};
var y = function(arg){ //四條
var a = arg.map(function(p){
return p.ch;
}).join(""),
mat = a.match(/(\w*)(\w)\2\2\2(\w*)/);
if( mat ){
return "y"+mat[2]+mat[1]+mat[3];
}
};
var x = function(arg){ //葫蘆
var a = arg.map(function(p){
return p.ch;
}).join(""),
mat;
if( mat = a.match(/(\w)\1(\w)\2\2/) ){
return "x" + mat[2] + mat[1];
}else if( mat = a.match(/(\w)\1\1(\w)\2/) ){
return "x" + mat[1] + mat[2];
}
};
var w = function(arg){ //同花
var a = arg,
t = a[0];
for (var i = 1; i < a.length; i++) {
if( a[i].color === t.color ){
t = a[i];
}else{
return;
}
};
return "w" + arg.map(function(p){
return p.ch;
}).join("");
};
var v = function(arg){ //順子
var a = arg,
t = a[0];
for (var i = 1; i < a.length; i++) {
if( a[i].num === t.num + 1 ){
t = a[i];
}else if( i === a.length-1 && t.num === 5 && a[i].num === 14){
t = a[0];
}else{
return;
}
};
return "v" + t.ch;
};
var u = function(arg){ //三條
var a = arg.map(function(p){
return p.ch;
}).join(""),
mat;
if( mat = a.match(/(\w*)(\w)\2\2(\w*)/) ){
return "u" + mat[2] + mat[1] + mat[3];
}
};
var t = function(arg){ //兩對
var a = arg.map(function(p){
return p.ch;
}).join(""),
mat;
if( mat = a.match(/(\w*)(\w)\2(\w)\3(\w*)/) ){
return "t" + mat[3] + mat[2] + mat[1] + mat[4];
}else if( mat = a.match(/(\w)\1(\w)(\w)\3/) ){
return "t" + mat[3] + mat[1] + mat[2];
}
};
var s = function(arg){ //一對
var a = arg.map(function(p){
return p.ch;
}).join(""),
mat;
if( mat = a.match(/(\w*)(\w)\2(\w*)/) ){
return "s" + mat[2] + mat[1] + mat[3];
}
};
var r = function(arg){ //高牌
return arg.map(function(p){
return p.ch;
}).join("");
};
var score = function(){
var a = [].map.call(arguments, function(p){
return new Poker(p);
}).sort(function(p1,p2){
return p1.num - p2.num;
});
console.log( a.join(",") );
return z(a) || y(a) || x(a) || w(a) || v(a) || u(a) || t(a) || s(a) || r(a);
};
console.log( score( 50, 49, 47, 46, 48 ) ); // 同花順
console.log( score( 36, 49, 23, 10, 48 ) ); // 四條
console.log( score( 36, 49, 23, 22, 48 ) ); // 葫蘆
console.log( score( 50, 40, 47, 43, 48 ) ); // 同花
console.log( score( 50, 36, 47, 46, 48 ) ); // 順子
console.log( score( 36, 49, 25, 22, 48 ) ); // 兩對
console.log( score( 36, 49, 20, 27, 47 ) ); // 一對
console.log( score( 36, 11, 20, 27, 47 ) ); // 高牌
2. 運(yùn)行效果如下圖所示:
希望本文所述對大家的javascript程序設(shè)計有所幫助。
相關(guān)文章
JavaScript使用encodeURI()和decodeURI()獲取字符串值的方法
這篇文章主要介紹了JavaScript使用encodeURI()和decodeURI()獲取字符串值的方法,實例分析了encodeURI()和decodeURI()函數(shù)解析字符串的相關(guān)技巧,需要的朋友可以參考下2015-08-08HTML5基于Tomcat 7.0實現(xiàn)WebSocket連接并實現(xiàn)簡單的實時聊天
WebSocket 是一種自然的全雙工、雙向、單套接字連接。這篇文章給大家介紹了HTML5基于Tomcat 7.0實現(xiàn)WebSocket連接并實現(xiàn)簡單的實時聊天,感興趣的朋友一起學(xué)習(xí)吧2016-10-10JavaScript實現(xiàn)的商品搶購倒計時功能示例
這篇文章主要介紹了JavaScript實現(xiàn)的商品搶購倒計時功能,可實現(xiàn)分秒級別的實時顯示倒計時效果,涉及js日期時間計算與頁面元素動態(tài)操作相關(guān)技巧,需要的朋友可以參考下2017-04-04JavaScript?canvas實現(xiàn)水球加載動畫
這篇文章主要為大家詳細(xì)介紹了JavaScript?canvas實現(xiàn)水球加載動畫,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-04-04用js將long型數(shù)據(jù)轉(zhuǎn)換成date型或datetime型的實例
下面小編就為大家?guī)硪黄胘s將long型數(shù)據(jù)轉(zhuǎn)換成date型或datetime型的實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07如何將JavaScript將數(shù)組轉(zhuǎn)為樹形結(jié)構(gòu)
我們經(jīng)常會碰到樹形數(shù)據(jù)結(jié)構(gòu),比方組織層級、省市縣或者者動植物分類等等數(shù)據(jù),那么如何將JavaScript將數(shù)組轉(zhuǎn)為樹形結(jié)構(gòu),本文就詳細(xì)的來了解一下2021-06-06一種新的javascript對象創(chuàng)建方式Object.create()
這篇文章主要介紹了一種新的javascript對象創(chuàng)建方式Object.create(),感興趣的小伙伴們可以參考一下2015-12-12