day13集合框架

集合框架
集合框架
集合框架
Java 集合框架

01 List接口

List接口
List接口

02 Set接口

Set接口
Set接口

03 Map接口

Map接口

04 泛型

泛型
泛型

05 Collections工具类

Collections工具类

06 Arrays工具类

Arrays工具类

07 练习

list足球队

  • 案例介绍

按照斗地主的规则,完成洗牌发牌的动作。
具体规则:
使用54张牌打乱顺序,三个玩家参与游戏,三人交替摸牌,每人17张牌,最后三张留作底牌。

// https://www.cnblogs.com/zs6666/p/5914785.html
import java.util.ArrayList;
import java.util.List;
import java.util.Random;

public class ListTest {

    public static void main(String[] args) {
        
        List<String> a=new ArrayList<>(); //创建一个List集合对象,多态
        a.add("科特迪瓦"); //// 往 尾部 添加 指定元素
        a.add("阿根廷");
        a.add("澳大利亚");
        a.add("塞尔维亚");
        a.add("荷兰");
        a.add("尼日利亚");
        a.add("日本");
        a.add("美国");
        a.add("中国");
        a.add("新西兰");
        a.add("巴西");
        a.add("比利时");
        a.add("韩国");
        a.add("喀麦隆");
        a.add("洪都拉斯");
        a.add("澳大利亚");
        
        
        Random ran = new Random();
        String b ;
        for(int i =1;i<=4;i++)
        {
            System.out.println(i+"组"); //输出随机获得的String
            System.out.println(a.size());
            for(int j = 0;j<4;j++)
            {
                b = a.get(ran.nextInt(a.size())); //获取指定索引处的元素
                System.out.print("   "+b);
                a.remove(b); //在集合中删除输出的String
            }
            System.out.println("\n");       
        }
        
    }
}
  • 案例分析

发牌

  • 准备牌:
    牌可以设计为一个ArrayList,每个字符串为一张牌。
    每张牌由花色数字两部分组成,我们可以使用花色集合与数字集合嵌套迭代完成每张牌的组装。
    牌由Collections类的shuffle方法进行随机排序。
  • 发牌
    将每个人以及底牌设计为ArrayList,将最后3张牌直接存放于底牌,剩余牌通过对3取模依次发牌。
  • 看牌
    直接打印每个集合。
import java.util.ArrayList;
import java.util.Collections;

public class Poker {
    public static void main(String[] args) {
        /*
        * 1: 准备牌操作
        */
        //1.1 创建牌盒 将来存储牌面的 
        ArrayList<String> pokerBox = new ArrayList<String>();
        //1.2 创建花色集合
        ArrayList<String> colors = new ArrayList<String>();

        //1.3 创建数字集合
        ArrayList<String> numbers = new ArrayList<String>();

        //1.4 分别给花色 以及 数字集合添加元素
        colors.add("♥");
        colors.add("♦");
        colors.add("♠");
        colors.add("♣");

        for(int i = 2;i<=10;i++){
            numbers.add(i+"");
        }
        numbers.add("J");
        numbers.add("Q");
        numbers.add("K");
        numbers.add("A");

        //1.5 创造牌  拼接牌操作
        // 拿出每一个花色  然后跟每一个数字 进行结合  存储到牌盒中
        for (String color : colors) {
            //color每一个花色 
            //遍历数字集合
            for(String number : numbers){
                //结合
                String card = color+number;
                //存储到牌盒中
                pokerBox.add(card);
            }
        }

        //1.6大王小王
        pokerBox.add("小☺");
        pokerBox.add("大☠");	  
        
        // System.out.println(pokerBox);
        //洗牌 是不是就是将  牌盒中 牌的索引打乱 
        // Collections类  工具类  都是 静态方法
        // shuffer方法   
        /*
         * static void shuffle(List<?> list) 
         *     使用默认随机源对指定列表进行置换。 
         */
        //2:洗牌
        Collections.shuffle(pokerBox);
        //3 发牌
        //3.1 创建 三个 玩家集合  创建一个底牌集合
        ArrayList<String> player1 = new ArrayList<String>();
        ArrayList<String> player2 = new ArrayList<String>();
        ArrayList<String> player3 = new ArrayList<String>();
        ArrayList<String> dipai = new ArrayList<String>();	  

        //遍历 牌盒  必须知道索引   
        for(int i = 0;i<pokerBox.size();i++){
            //获取 牌面
            String card = pokerBox.get(i);
            //留出三张底牌 存到 底牌集合中
            if(i>=51){//存到底牌集合中
                dipai.add(card);
            } else {
                //玩家1   %3  ==0
                if(i%3==0){
                  	player1.add(card);
                }else if(i%3==1){//玩家2
                  	player2.add(card);
                }else{//玩家3
                  	player3.add(card);
                }
            }
        }
        //看看
        System.out.println("令狐冲:"+player1);
        System.out.println("田伯光:"+player2);
        System.out.println("绿竹翁:"+player3);
        System.out.println("底牌:"+dipai);  
	}
}

猜你喜欢

转载自blog.csdn.net/hezuijiudexiaobai/article/details/107629017