java洗牌算法问题

java洗牌算法问题,第1张

你指的是Card里的toString方法

 public String toString() {

  String aa = suit + " " + num + "  "

  return aa

 }

toString这个方法一般在 System.out.print时使用,这个是打印出String,JVM就是默认调用类的toSting方法

注:所有类都有toString方法,默认是当前对象的hashcode,即内存地址

所以在发牌是打印

 public void dealcard()//发牌

    {

    颂虚隐    for(int i=0i<52i++)

        {

            if(i%4==0&&i!=0){

             System.out.println()  //每发4张牌输出换行誉绝

            }

            // 就是这里,默认调用card的toString方法

             System.out.print(card[i]) //依次输出 发的牌

   野厅     }

    }

使用JAVA编写以下程序:

1、请定义一个名为Card的扑克牌类,该类有两个private访问权限的字符串变量face和suit;分别描述一张牌的牌面值(如:A、K、Q、J、10、9、……3、2等)和花色(如:“黑桃”、“红桃”、“梅花”、“方块”);定义Card类中的public访问权限的构造方法,为类中的变量赋值;定义protected访问权限的方法getFace(),得到扑克牌的牌面值;定义protected访问权限的方法getSuit(),得到扑克牌的花色;定义方法toString(),返回表示扑克牌的花色和牌面值字符串(如“红桃A”、“梅花10”等)。

2、若应用程序的main方法中,定义字符串数组f和s;分别表示扑克牌的牌面值和花色;定义52个元素的Card类型数组deck,用来存放4个花色的52张牌。如下让衡所示。

String f[] = {"A","2","3","4","5","6","7","8","9","10","J","Q","K"}

String s[] = {"黑桃","红桃","梅花","方块"}

Card deck = new Card[52];

(1)使用Card类的构造方法给deck数组的52张牌赋值,要求数组中先存放黑桃花色的A、2、3、……、K;然后是红桃花色的A、2、3、……、K;梅花花色的A、2、3、……、K;方块花色的A、2、3、……、K。请写出实现上述功能的程序段。

(2)请编写模拟洗牌的完整程序,即把数组deck中的埋冲扑克牌随机打乱存放顺序。

原题如下:

引用内容

private String face// A, K, Q, J, 10, ... 2

private String suit// Spade, Heart, Club, Diamond

public Card(String suit, String face) {

this.face = face

this.suit = suit

}

protected String getFace() {

return face

}

protected String getSuit() {

return suit

}

public String toString() {

return suit + " " + face

}

解题,完成程序解:

程序代码

package poker

public class Card {

private String face// A, K, Q, J, 10, ... 2

private String suit// Spade, Heart, Club, Diamond

public Card(String suit, String face) {

this.face = face

this.suit = suit

}

protected String getFace() {

return face

}

protected String getSuit() {

return suit

}

public String toString() {

return suit + " " + face

}

public static void shuffle(Card[] deck, int startIndex, int size,

int splitIndex) { //shuffle洗牌

System.out.println("startIndex:" + startIndex)

if (splitIndex * 2 >size) { //if rand is 30

Card.swap(deck, startIndex, splitIndex, size - splitIndex)//[52]、0、坦液做30、22

shuffle(deck, size - splitIndex, splitIndex, size - splitIndex)//[52]、22、30、22

} else if (splitIndex * 2 <size) { //if rnd is 10

Card.swap(deck, startIndex, size - splitIndex, splitIndex)//[52]、0、42、10

shuffle(deck, startIndex, size - splitIndex, splitIndex)//[52]、0、42、10

} else {

Card.swap(deck, startIndex, splitIndex, splitIndex)

}

}

public static void swap(Card[] deck, int srcIndex, int dstIndex, int size) { //交换

//SRC是在本位置显示:source的缩写,源的意思 HREF是点击后连接的目标:HyperlinkReference,超链接引用

String face = ""

String suit = ""

for (int i = 0i <sizei++) {

face = deck[srcIndex + i].face

suit = deck[srcIndex + i].suit

deck[srcIndex + i].face = deck[dstIndex + i].face

deck[srcIndex + i].suit = deck[dstIndex + i].suit

deck[dstIndex + i].face = face

deck[dstIndex + i].suit = suit

}

}

/**

* @param args

*/

public static void main(String[] args) {

//第一问解答

Card[] deck = new Card[52]

String f[] = {"A", "2", "3", "4", "5", "6", "7", "8", "9", "10", "J",

"Q", "K"}

String s[] = {"Spade", "Heart", "Club", "Diamond"}

for (int i = 0i <s.lengthi++) {

for (int j = 0j <f.lengthj++) {

deck[i * 13 + j] = new Card(s[i], f[j])//依次存入数组之中,每13张一回合

}

}

//第二问解答

int rnd = 0

int numOfShuffle = 10

for (int i = 0i <numOfShufflei++) {

rnd = (int) Math.abs(Math.random() * 52)//Math.random()返回大于或等于 0.0 但小于 1.0 的伪随机 double 值。

Card.shuffle(deck, 0, deck.length, rnd)

}

// Test

/*

for (int i=0i<deck.lengthi++)

{

System.out.println(deck[i])

} */

}

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12484633.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存