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

需求:这个酒店有五层,并且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. 基于spring cloud OAuth2的微服务授权验证服务搭建的一些坑, 包括401,client_secret,invalid_scope等问题

    一 先贴成功图,用的是springcloud Finchley.SR1版本,springboot版本2.0.6 问题一: 返回401, Unauthorized 出现这个问题原因很多:首先确保方法开启 ...

  2. Nacos 配置MySQL8.0持久化

    问题描述 官网下载的Nacos mysql由于驱动过低只支持5.X版本,使用8.X版本的mysql时无法正常启动 解决办法 克隆nacos源码(branch 1.0.0-RC3) master等分支也 ...

  3. python 学习笔记2 匿名函数

    # 匿名函数 lambda a,b : a+b# a.j.from functools import reduce students = [{'name': '张三', 'age': 18, 'hei ...

  4. python如何从内存地址上加载pythn对象

    python如何从内存地址上加载pythn对象 在python中我们可以通过id函数来获取某个python对象的内存地址,或者可以通过调用对象的__repr__魔术函数来获取对象的详细信息 def t ...

  5. 实验3: DHCP 基本配置

    实验3-1: DHCP 基本配置 实验目的通过本实验可以掌握:(1)DHCP 的工作原理和工作过程(2)DHCP 服务器的基本配置和调试(3)客户端配置 拓扑结构 实验步骤n    步骤1:配置路由器 ...

  6. 用javascript修改html元素的class

    document.getElementById("collins_contentWrp").className="content-wrp dict-container c ...

  7. The Top 500 Worst Passwords (2008)

    Top 100 123456 password 12345678 1234 pussy 12345 dragon qwerty 696969 mustang letmein baseball mast ...

  8. Huffman编码和解码

    一.Huffman树 定义: 给定n个权值作为n个叶子结点,构造一棵二叉树,若该树的带权路径达到最小,这样的二叉树称为最优二叉树,也称为霍夫曼树(Huffman树). 特点:     Huffman树 ...

  9. GORM入门指南

    gorm是一个使用Go语言编写的ORM框架.它文档齐全,对开发者友好,支持主流数据库. gorm介绍 Github GORM 中文官方网站内含十分齐全的中文文档,有了它你甚至不需要再继续向下阅读本文. ...

  10. HDU_2510_打表

    http://acm.hdu.edu.cn/showproblem.php?pid=2510 dfs打表. #include<iostream> #include<cstdio> ...