`

java集合类的数据结构灵活应用

阅读更多

package cn.itcast_03;

import java.util.ArrayList;
import java.util.Collections;

/*
 * 模拟斗地主洗牌和发牌
 *
 * 分析:
 *   A:创建一个牌盒
 *   B:装牌
 *   C:洗牌
 *   D:发牌
 *   E:看牌
 */
public class PokerDemo {
 public static void main(String[] args) {
  // 创建一个牌盒
  ArrayList<String> array = new ArrayList<String>();

  // 装牌
  // 黑桃A,黑桃2,黑桃3,...黑桃K
  // 红桃A,...
  // 梅花A,...
  // 方块A,...
  // 定义一个花色数组
  String[] colors = { "♠", "♥", "♣", "♦" };
  // 定义一个点数数组
  String[] numbers = { "A", "2", "3", "4", "5", "6", "7", "8", "9", "10",
    "J", "Q", "K" };
  // 装牌
  for (String color : colors) {
   for (String number : numbers) {
    array.add(color.concat(number));
   }
  }
  array.add("小王");
  array.add("大王");

  // 洗牌
  Collections.shuffle(array);

  // System.out.println("array:" + array);

  // 发牌
  ArrayList<String> fengQingYang = new ArrayList<String>();
  ArrayList<String> linQingXia = new ArrayList<String>();
  ArrayList<String> liuYi = new ArrayList<String>();
  ArrayList<String> diPai = new ArrayList<String>();

  for (int x = 0; x < array.size(); x++) {
   if (x >= array.size() - 3) {
    diPai.add(array.get(x));
   } else if (x % 3 == 0) {
    fengQingYang.add(array.get(x));
   } else if (x % 3 == 1) {
    linQingXia.add(array.get(x));
   } else if (x % 3 == 2) {
    liuYi.add(array.get(x));
   }
  }

  // 看牌
  lookPoker("风清扬", fengQingYang);
  lookPoker("林青霞", linQingXia);
  lookPoker("刘意", liuYi);

  lookPoker("底牌", diPai);
 }

 public static void lookPoker(String name, ArrayList<String> array) {
  System.out.print(name + "的牌是:");
  for (String s : array) {
   System.out.print(s + " ");
  }
  System.out.println();
 }
}

测试多次
输出:

风清扬的牌是:小王 ♦8 ♥10 ♦5 ♣Q ♥4 ♣7 ♣8 ♠9 ♦A ♠4 ♥7 ♠2 ♦6 ♠7 ♥8 ♣9
林青霞的牌是:♦Q ♥5 ♥9 ♠A ♠6 ♣3 ♠Q ♦7 ♦10 ♠K ♦K ♣K ♥3 ♠10 ♠8 ♥6 ♠5
刘意的牌是:♥2 ♠3 ♥A ♠J ♥Q ♣J ♦J ♣4 ♥K ♦4 ♣6 ♣5 ♥J ♦3 ♦2 大王 ♦9
底牌的牌是:♣A ♣2 ♣10
输出:风清扬的牌是:♦2 ♠7 ♥9 ♦9 ♥3 ♥7 ♠A ♠Q ♣2 ♣4 ♠J ♦4 ♦A ♣5 ♠3 ♥K ♦5
林青霞的牌是:♥10 ♦8 ♥2 ♣Q ♣8 ♠K ♦3 ♠4 ♣7 ♠6 ♠9 ♦Q ♠10 ♣3 ♥5 小王 ♣J
刘意的牌是:♥4 ♠2 ♦J ♦7 ♦K ♥8 ♣6 ♥J ♣10 ♥A ♦10 ♠8 ♠5 ♥Q ♣9 ♥6 ♣K
底牌的牌是:♦6 大王 ♣A

先保存在这里,慢慢领悟

 

  • 大小: 7.8 KB
分享到:
评论

相关推荐

    java自定义集合类

    自定义集合类的一个例子是,你可能想要创建一个支持优先级排序的队列,这时可以实现一个`PriorityQueue`类,基于最小堆数据结构实现,允许用户通过优先级插入和删除元素。 在实际应用中,自定义集合类可以提高代码...

    Java集合类详解总结

    ### Java集合类详解总结 在Java编程中,集合框架(Collection Framework)是处理一组对象的强大工具,它提供了标准的数据结构来存储和操作这些对象。Java集合框架主要包括`Collection`、`Set`、`List`、`Queue`、`...

    java中数据结构应用实例

    在Java编程语言中,数据结构的应用是至关重要的,它直接影响到程序的效率和性能。数据结构是组织、管理和存储数据的方式,以便于高效地访问和修改。本实例将深入探讨几种常见的数据结构及其在Java中的实现,包括数组...

    数据结构与问题求解Java语言

    作者采用了独特的方法将数据结构分成说明和实现两部分,并充分利用了已有的数据结构库(Java集合类API)。本书分为四个部分:第一部分讨论适合大多数应用的集合类API的一个子集,并覆盖基本的算法分析技术、递归和...

    Java 集合与数据结构详解1

    这些算法对于理解排序原理很有帮助,但在实际应用中,Java集合框架中的Collections类提供了更高效的排序方法,如使用快速排序和归并排序。 HashMap的源码分析是一个深入的话题,它涉及到位运算、哈希函数、扩容策略...

    Java集合类性能分析

    ### Java集合类性能分析 #### 一、Java集合框架概览 Java集合框架是一个非常重要的概念,它提供了处理数据集合的标准方法。集合框架的核心部分主要包括集合接口、抽象类以及具体的实现类。 - **集合接口**:Java...

    java集合类学习汇总

    Java集合类是Java编程语言中用于存储对象的重要工具,它们提供了灵活的数据组织方式,使得开发者可以高效地管理和操作数据。本篇文章将详细讲解Java集合框架中的核心类,并探讨其使用场景和相关数据结构。 首先,...

    Java版本数据结构实验报告

    Java集合框架中的TreeSet和TreeMap就是以红黑树为底层实现的。 图数据结构用于表示对象之间的复杂关系,如社交网络、交通网络等。在Java中,可以使用邻接矩阵或邻接表来表示图。图的遍历算法,如深度优先搜索(DFS...

    免费:数据结构(c与c++与java三本书高清晰版).rar

    JAVA版的《数据结构》则可能强调Java平台特有的数据结构实现,如集合框架(Collection Framework),其中包括接口(如List、Set和Queue)和实现(如ArrayList、LinkedList、HashSet、TreeSet等)。Java的这些数据...

    JAVA常用数据结构和算法

    本资源"JAVA常用数据结构和算法"聚焦于这一核心主题,旨在深化对Java中数据结构及其算法应用的理解。 数据结构是存储和组织数据的方式,它能影响数据的存取效率。Java提供了多种内置数据结构,如数组、链表、栈、...

    实用数据结构教程_Java语言描述.zip

    本教程“实用数据结构教程_Java语言描述”涵盖了这个主题,旨在帮助学习者深入理解和应用Java中的数据结构。 1. 数组:数组是最基本的数据结构,它允许存储固定大小的同类型元素序列。在Java中,数组可以是一维、二...

    Java集合类原理详解.pdf

    ### Java集合类原理详解 #### 1. 集合框架概述 集合框架是Java编程语言的核心组件之一,用于组织和操作数据集。它提供了一种灵活高效的方式来存储和访问对象集合,支持多种数据结构,如列表(List)、集(Set)、映射...

    java集合思维导图

    Java集合框架是Java编程语言中的一个核心部分,它为数据存储和管理提供了高效且灵活的解决方案。本思维导图及总结旨在深入理解并掌握Java集合的相关概念和使用方法。 首先,我们来了解一下Java集合框架的基本构成。...

    java 集合

    关于源码,Java集合框架的实现类通常包含了许多内部细节,比如数据结构的优化、线程安全的考虑等。例如,`ArrayList`底层使用的是动态增长的数组,而`LinkedList`则由双向链表构成,它们在插入和删除操作上的性能...

    实用数据结构教程_Java语言描述

    在Java编程中,理解数据结构至关重要,因为它们是构建复杂算法和应用程序的基础。"实用数据结构教程_Java语言描述"这个资料提供了一个深入学习数据结构的平台,特别是针对Java程序员。 在Java中,数据结构主要分为...

    数据结构和Java集合框架《Data Structures and the Java Collections Framework》

    数据结构和Java集合框架是Java开发中的核心概念,它们对于高效地存储和处理数据至关重要。在Java编程中,集合框架是一组接口和类,提供了一种标准的方式来组织和操作对象的集合。本资源《Data Structures and the ...

    数据结构(Java版)电子教案

    本电子教案将深入探讨Java版的数据结构及其应用。 1. **数组**:数组是最基础的数据结构,它提供了按索引访问元素的能力。Java中的数组分为一维数组、二维数组以及多维数组,适用于存储同类型的数据集合。 2. **...

    超级适合java学习者使用的数据结构

    在Java领域,理解并能灵活运用数据结构是提升编程技能的关键步骤。本资源"超级适合java学习者使用的数据结构"针对Java学习者提供了一套全面、详细的数据结构教程,以面向对象的方式进行讲解,有助于读者深入理解数据...

    JAVA数据结构与算法(中英全)

    树结构如二叉树、红黑树等,广泛应用于搜索、排序等操作,例如Java集合框架中的TreeSet和TreeMap就是基于红黑树实现的。图数据结构则用于表示复杂的关系,如网络路由、社交网络等。 接下来是算法部分。算法是解决...

Global site tag (gtag.js) - Google Analytics