一、创建一个酒店的房间管理系统

需求:这个酒店有五层,并且1-2层是标准间,3-4层是双人间,5层是豪华间;我们需要实时的显现各个房间的使用状态,并且我们可以预定某一个房间。

package com.bjpowernode.java_learning;

​

import java.util.Scanner;

​

public class D87_1_ {

  public static void main(String[] args) {

    Scanner s = new Scanner(System.in);

    Hotel87 h = new Hotel87();

    h.print();

    while (s.hasNext()) {

      System.out.println("请输入您要预定的房间");

      String number = s.next();

      h.order(number);

      h.print();

    }

  }

}

class Room87{

  private String no;

  private String type;//标准间、双人间、豪华间

  private boolean isUse;//false表示空间,true表示占用

  /**

   * @param no

   * @param type

   * @param isUse

   */

  Room87(String no, String type, boolean isUse) {

    super();

    this.no = no;

    this.type = type;

    this.isUse = isUse;

  }

  public String getNo() {

    return no;

  }

  public void setNo(String no) {

    this.no = no;

  }

  public String getType() {

    return type;

  }

  public void setType(String type) {

    this.type = type;

  }

  public boolean isUse() {

    return isUse;

  }

  public void setUse(boolean isUse) {

    this.isUse = isUse;

  }

  public String toString() {

    return "{" + no +"," +(isUse?"占用":"空间") + "}";

  }

}

class Hotel87 {

  //房间

  Room87[][] rooms;

  //Constructer

  Hotel87(){

    //五层 每层十间

    rooms = new Room87[5][10];

    //赋值

    //1,2标准间

    //3,4双人间

    //5 豪华间

    for(int i=0;i<rooms.length;i++) {

      for(int j=0;j<rooms[i].length;j++) {

        if (i==0 || i==1) {

          rooms[i][j] = new Room87((i+1)*100+j+"","标准间",false);

        }

        if (i==2 || i==3) {

          rooms[i][j] = new Room87((i+1)*100+j+"","双人间",false);

        }

        if (i==4) {

          rooms[i][j] = new Room87((i+1)*100+j+"","豪华间",false);

        }

​

      }

    }

  }

  //对外提供一个打印酒店房间列表的方法

  public void print() {

    for(int i=0;i<rooms.length;i++) {

      for(int j=0;j<rooms[i].length;j++) {

        System.out.print(rooms[i][j] + " ");;

      }

      System.out.println();

    }

  }

  public void order(String no) {

    for(int i=0;i<rooms.length;i++) {

      for(int j=0;j<rooms[i].length;j++) {

        if(rooms[i][j].getNo().equals(no)) {

          //将该房间改为占用

          rooms[i][j].setUse(true);

          return;

        }

      }

    }

  }

}

二、HashSet

1.HashSet是set的一个实现类;

2.HashSet底层是一个HashMap;

3.哈希表是什么

三、源码:

D87_1_HotelManageSystem.java

D87_2_HashSet.java

https://github.com/ruigege66/Java/blob/master/D87_1_HotelManageSystem.java

https://github.com/ruigege66/Java/blob/master/D87_2_HashSet.java

2.CSDN:https://blog.csdn.net/weixin_44630050

3.博客园:https://www.cnblogs.com/ruigege0000/

4.欢迎关注微信公众号:傅里叶变换,个人公众号,仅用于学习交流,后台回复”礼包“,获取大数据学习资料

Java连载87-酒店管理系统练习、哈希表、函数的更多相关文章

  1. Java swing实现酒店管理系统

    今天给大家提供一个由今天给大家提供一个由Java swing实现的酒店管理系统,数据库采用sqlserver,我会贴上部分代码,完整的代码请看文章最下方下载,下面看代码: 1.主框架代码: packa ...

  2. Java知多少(79)哈希表及其应用

    哈希表也称为散列表,是用来存储群体对象的集合类结构. 什么是哈希表 数组和向量都可以存储对象,但对象的存储位置是随机的,也就是说对象本身与其存储位置之间没有必然的联系.当要查找一个对象时,只能以某种顺 ...

  3. java数据结构和算法09(哈希表)

    树的结构说得差不多了,现在我们来说说一种数据结构叫做哈希表(hash table),哈希表有是干什么用的呢?我们知道树的操作的时间复杂度通常为O(logN),那有没有更快的数据结构?当然有,那就是哈希 ...

  4. 源码:Java集合源码之:哈希表(二)

    要想知道一个元素是否在数组或链表中,只能从前向后挨个对比,无论是数组还是链表,其对数据的查询表现都比较无力.在的二叉排序树中,还会将数据排序以进行二分查找,将时间复杂度从O(n)降低到O(lg n). ...

  5. 【编程学习】浅谈哈希表及用C语言构建哈希表!

    哈希表:通过key-value而直接进行访问的数据结构,不用经过关键值间的比较,从而省去了大量处理时间. 哈希函数:选择的最主要考虑因素--尽可能避免冲突的出现 构造哈希函数的原则是: ①函数本身便于 ...

  6. Java编写ArrayBasic制作一个简单的酒店管理系统

    听老师讲了一些ArrayBasic的一些知识,让制作一个酒店管理系统,要求:显示酒店所有房间列表,预订房间.... 经过老师的指导写了一个代码,如下: import java.util.Scanner ...

  7. java简单学生成绩管理系统

    题目要求: 一. 数据结构要求:(5 分) 1.定义 ScoreInformation 类,其中包括七个私有变量(stunumber, name, mathematicsscore, englishi ...

  8. Java连载69-接受输入、用数组模拟栈

    一.编写一个酒店管理系统 1.直接上代码 package com.bjpowernode.java_learning; ​ public class D69_1_ { //编写一个程序模拟酒店的管理系 ...

  9. 实用干货!Java开发企业级权限管理系统视频教程

    全程手把手带你运用Java技术栈,打造一套基于最流行的RBAC拓展模型的,分布式的,有界面的,高灵活性,高拓展性的企业级权限管理系统.学完本课程你将可以轻松应对绝大多数企业开发中与权限管理及后台系统相 ...

随机推荐

  1. linux下oracle调试小知识

    1.oracle 安装下的/u01/diag/rdbms/orcl/HOF/incident目录下是什么文件?答:每当一个错误发生的时候,oracle会创建一个incident,并且分配一个INCID ...

  2. MYSQL-innobackupex备份脚本

    自动化运维,是数据库管理员的不懈追求.目前出现了一些数据库自动管理平台,但出现时间较短,不够稳定.最常用的工具依然是shell脚本. 现在需要管理的某mysql数据库,数据量在800G,使用dump备 ...

  3. Linux(Centos)安装Java JDK及卸载

    步骤一.下载安装包 a.   因为Java JDK区分32位和64位,所以安装之前需先判断一下我们操作系统为多少位·,命令如下: uname -a 解释:如果有x86_64就是64位的,没有就是32位 ...

  4. Gloang Swagger

    功能 自动化生产接口文档 安装 # 安装swaggo get -u github.com/swaggo/swag/cmd/swag # 安装 gin-swagger go get -u github. ...

  5. Qt实现简易计算器

    麻烦到不能再麻烦的实现,简单到不能再简单的思路. calc.h #ifndef CALC_H #define CALC_H #include <QtWidgets/QMainWindow> ...

  6. session学习总结【session原理、应用、与cookie区别】

    session原理 session也是一种记录浏览器状态的机制,但与cookie不同的是,session是保存在服务器中. 由于http是无状态协议,当服务器存储了多个用户的session数据时,如何 ...

  7. react项目中引用amap(高德地图)坑

    最近在写一个react项目,用到了需要定位的需求,于是乎自己决定用高德地图(AMap),但是react官方文档的案列很少,大多都是原生JS的方法. 在调用amap的 Geocoder Api 时,一直 ...

  8. VFP 用 SPT 来发布一条 SELECT 到一个新的 SQL Server 表

    为了发布一条 SQL SELECT 语句来创建一个新的 SQL Server 表,  SQL Server 数据库的 select into/bulkcopy 选项必须是可用的. 在默认情况下, 对于 ...

  9. Python 实现转堆排序算法原理及时间复杂度(多图解释)

    原创文章出自公众号:「码农富哥」,欢迎转载和关注,如转载请注明出处! 堆基本概念 堆排序是一个很重要的排序算法,它是高效率的排序算法,复杂度是O(nlogn),堆排序不仅是面试进场考的重点,而且在很多 ...

  10. mybatis缓存,包含一级缓存与二级缓存,包括ehcache二级缓存

    一,引言 首先我们要明白一点,缓存所做的一切都是为了提高性能.明白了这一点下面我们开始进入正题. 二,mybatis缓存概要 ①.mybatis的缓存有两种,分别是一级缓存和二级缓存.两者都属于查询缓 ...