php对扑克牌进行排序,C#代码实现扑克牌排序的几种方式
撲克牌游戲,總是能用到很多的手牌排序,總結(jié)了幾種方式供參考,順便記錄一下方便以后使用。
我做的這個(gè)是由(1-13:黑桃A-K || 14 - 26:紅桃 || 27 - 39:梅花 || 39 - 52 : 方片 || 53.54:小王.大王)表示的一副撲克牌,這樣對(duì)數(shù)組除以13等于撲克花色(如:25/13 = 2 是紅桃),對(duì)數(shù)組值取模等于撲克點(diǎn)數(shù)(如:25%13 = 12 是Q),這樣25就表示了紅桃Q的撲克牌。
當(dāng)處理特殊規(guī)則的時(shí)候單獨(dú)寫一個(gè)List,在組拼就可以了。
比如說:賴子斗地主的時(shí)候,當(dāng)選出賴子牌之后,就需要對(duì)手牌再次排序,那么new List來存一下賴子牌,選定賴子牌之后,存到list中,再次調(diào)用排序,組拼就可以實(shí)現(xiàn),你想要的手牌排序的數(shù)組,那么在通過某種形式讓他顯示出來就可以了。
上代碼 :
//參數(shù):要排序的牌值數(shù)組 & 數(shù)組長(zhǎng)度
public int[] PaiXu(int[] card, int number = 0)
{
//Debug.Log(" ... 對(duì)手牌 進(jìn)行 牌值 花色 的排序 ... ... ");
if (number == 0){ number = card.Length; }
if (card.Length == 0){ return card; }
// ========== 根據(jù)牌值進(jìn)行排序 ===============
int temp = 0;
for (int i = 0; i < card.Length; i++) //冒泡排序... 從大到小
{
for (int j = 0; j < card.Length - 1 - i; j++)
{
if (card[j] < card[j + 1])
{
temp = card[j];
card[j] = card[j + 1];
card[j + 1] = temp;
}
}
}
List hei = new List();
List hong = new List();
List mei = new List();
List fang = new List();
List wang = new List();
for (int i = 0; i < card.Length; i++)
{
#region ======= 根據(jù)花色分組 ..大小王 單獨(dú)一組 ...后續(xù)對(duì)花色中的 A 單獨(dú)處理 =========
switch (sendFlower(card[i]))
{
case 3: //黑桃
hei.Add(card[i]);
break;
case 2: //紅桃
hong.Add(card[i]);
break;
case 1: //梅花
mei.Add(card[i]);
break;
case 0: //方片
fang.Add(card[i]);
break;
case 4: //小王
case 5: //大王
wang.Add(card[i]);
break;
}
#endregion
}
QuA(hei); // 對(duì)A 的單獨(dú)處理
QuA(hong);
QuA(mei);
QuA(fang);
#region ========== 合并 排序后的牌組========
List cardlist = new List();
for (int i = 0; i < wang.Count; i++) //王
{
cardlist.Add(wang[i]);
}
// ==========合并 組拼 ============
List cardtemp = new List();
cardtemp = PaiXuZuPin(hei, hong, mei, fang);
for (int i = 0; i < cardtemp.Count; i++)
{
cardlist.Add(cardtemp[i]);
}
int[] cards = new int[cardlist.Count];
for (int i = 0; i < cardlist.Count; i++)
{
cards[i] = cardlist[i];
}
#endregion
return cards;
}
///
/// 取A -- 把每個(gè)花色牌中的A,放到前面(A.K.Q.J...)
///
/// 花色牌
void QuA(List hei)
{
if (hei.Count == 0) return;
List cardlist = new List();
for (int i = 0; i < hei.Count; i++) // 將牌添加到新列表
{
cardlist.Add(hei[i]);
}
if (hei.Count > 2)
{
if (hei[hei.Count - 2] % 13 == 1) //如果有兩個(gè)A (對(duì)兩幅牌的處理)
{
cardlist.Insert(0, hei[hei.Count - 2]);
cardlist.Insert(0, hei[hei.Count - 1]);
for (int i = 0; i < hei.Count; i++)
{
hei[i] = cardlist[i];
}
return;
}
}
if (hei[hei.Count - 1] % 13 == 1) //如果有一個(gè)A
{
cardlist.Insert(0, hei[hei.Count - 1]);
}
for (int i = 0; i < hei.Count; i++)
{
hei[i] = cardlist[i];
}
}
///
/// 根據(jù)傳入牌組 的順序 進(jìn)行組拼
///
public List PaiXuZuPin(List one, List two, List three, List four)
{
List cardlist = new List();
for (int i = 0; i < one.Count; i++)
{
cardlist.Add(one[i]);
}
for (int i = 0; i < two.Count; i++)
{
cardlist.Add(two[i]);
}
for (int i = 0; i < three.Count; i++)
{
cardlist.Add(three[i]);
}
for (int i = 0; i < four.Count; i++)
{
cardlist.Add(four[i]);
}
return cardlist;
}
///
/// 根據(jù)牌值取花色 5:大王 | 4:小王 | 3:黑桃 | 2:紅桃 | 1:梅花 | 0:方片
///
///
public int sendFlower(int card)
{
if (card >= 1 && card <= 13)
{
return 3;
}else if (card >= 14 && card <= 26)
{
return 2;
}
else if (card >= 27 && card <= 39)
{
return 1;
}
else if (card >= 40 && card <= 52)
{
return 0;
}
else if (card == 53)
{
return 4;
}
return 5;
}
PS:代碼僅供參考,優(yōu)化自行處理
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
總結(jié)
以上是生活随笔為你收集整理的php对扑克牌进行排序,C#代码实现扑克牌排序的几种方式的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 公共界面_公共建筑东营市档案馆能耗计量分
- 下一篇: c#中connect函数_C#.NET