A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

       public class Test3 {
        /**
         * * A:案例演示
         * 模拟斗地主洗牌和发牌并对牌进行排序的代码实现
         *
         *问题在下面有※的地方!么么哒!!!!!!
         */
        public static void main(String[] args) {
                //1,买一副扑克,其实就是自己创建一个集合对象,将扑克牌存储进去
                String[] num = {"3","4","5","6","7","8","9","10","J","Q","K","A","2"};
                String[] color = {"红桃","黑桃","方片","梅花"};
                HashMap<Integer, String> hm = new HashMap<>();                                        //存储索引和扑克牌
                ArrayList<Integer> list = new ArrayList<>();                                        //存储索引
                int index = 0;
     //※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※
       /** 下面的代码咱们不看!!!!!!!我想要问的是上面.
      String[] color = {"红桃","黑桃","方片","梅花"};     这个可以改成如下代码
      String[] color = {"♥","♠","♦","♣"};     有的编译器可能不支持这种符号,但我的可以!所以先不要纠结这这里!!!
       那么我们所知道的斗地主的那图形是有颜色区分的,那么在编译器里能改成红色的桃心么?如果可以该怎样改???
       还有,如果不用这种图形,用char的方式来做,能打印出黑桃,红桃的形状么?我用的是eclipse,我打印出来的是:□这种的!*/


        /************************************************************************************************************************/       
                //拼接扑克牌并索引和扑克牌存储在hm中
                for(String s1 : num) {                                                                                        //获取数字
                        for(String s2 : color) {                                                                        //获取颜色
                                hm.put(index, s2.concat(s1));
                                list.add(index);                                                                                //将索引0到51添加到list集合中
                                index++;
                        }
                }
                //将小王添加到双列集合中
                hm.put(index, "小王");
                list.add(index);                                                                                                //将52索引添加到集合中
                index++;
                hm.put(index, "大王");
                list.add(index);                                                                                                //将52索引添加到集合中
               
                //2,洗牌
                Collections.shuffle(list);
                //3,发牌
                TreeSet<Integer> gaojin = new TreeSet<>();
                TreeSet<Integer> longwu = new TreeSet<>();
                TreeSet<Integer> me = new TreeSet<>();
                TreeSet<Integer> dipai = new TreeSet<>();
               
                for(int i = 0; i < list.size(); i++) {
                        if(i >= list.size() - 3) {
                                dipai.add(list.get(i));                                                        //将三张底牌存储在底牌集合中
                        }else if(i % 3 == 0) {
                                gaojin.add(list.get(i));
                        }else if(i % 3 == 1) {
                                longwu.add(list.get(i));
                        }else {
                                me.add(list.get(i));
                        }
                }
               

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马