一、编写一个酒店管理系统

1.直接上代码

package com.bjpowernode.java_learning;

​

public class D69_1_ {

  //编写一个程序模拟酒店的管理系统:预定房间、退房.......

  public static void main(String[] args) {

  }

}

class Room{

  String no;

  String type;//“标准间”“双人间”“豪华间”

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

}

class Hotel{

  //规定酒店:五层,每层十个房间,1,2层标准间,3,4双人间,5层豪华间

  Room[][] rooms;

  //无参数

  Hotel(){

    this(5,10);

  }

  Hotel(int rows,int cols){

    rooms = new Room[rows][cols];

    /*

     * rooms[0][0]....

     * rooms[4][9]....

     */

  }

  //对外提供预定方法

}

二、接受用户键盘输入

1.下面演示如何接受用户的输入


package com.bjpowernode.java_learning;

​

import java.util.Scanner;

​

public class D69_2_AcceptUserInput {

  public static void main(String[] args) {

    Scanner s = new Scanner(System.in);

    //程序运行到此处,停下来,等待用户的输入

    String userInput = s.next();

    System.out.println("您输入了:"+userInput);

  }

}

​

三、使用数组模拟栈Stack

package com.bjpowernode.java_learning;

​

public class D69_3_ArraysSimulateStack {

  public static void main(String[] args) {

    Stack s = new Stack(2);

    User69 u1 = new User69("jfidsa",12);

    User69 u2 = new User69("jfiddfsa",12);

    User69 u3 = new User69("jfidfdsfsa",12);

    try {

      s.push(u1);

      s.push(u2);

      s.push(u3);

    }catch(StackOperationException e) {

      System.out.println(e);

    }

//      System.out.println(s.pop());

  }

​

}

class Stack{

  //使用数组存储数据,注意栈可以存储多个引用类型的元素

  Object[] elements;

  //指向栈顶元素上方的一个帧

  int index;

  //栈默认的初始化容量是10

  Stack(){

    this(10);

  }

  Stack(int max){

    elements = new Object[max];

  }

  //栈应该对外提供一个压栈的方法

  public void push(Object element) throws StackOperationException{

    if (index == elements.length) {

      throw new StackOperationException("栈已经满了");

    }

    elements[index++] = element;

  }

  //对外提供一个弹栈的方法

  public Object pop() throws StackOperationException{

    if(index == 0) {

      throw new StackOperationException("栈已经空了");

    }

    return elements[--index];

  }

}

​

class User69{

  String name;

  int age;

  User69(String name,int age){

    this.name = name;

    this.age = age;

  }

  public String toString() {

    return "User是我";

  }

}

class StackOperationException extends Exception{

  public StackOperationException() {}

  public StackOperationException(String msg) {

    super(msg);

  }

}

四、源码:

D69_1_HotelManageSystem.java

D69_2_AcceptUserInput.java

D69_3_ArraysSimulateStack.java

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

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

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

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

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

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

Java连载69-接受输入、用数组模拟栈的更多相关文章

  1. 数组模拟栈(C语言)

    用数组模拟栈的实现: #include <stdio.h> #include <stdlib.h> #define STACK_SIZE 100 typedef struct ...

  2. Java数组模拟栈

    一.概述 注意:模拟战还可以用链表 二.代码 public class ArrayStack { @Test public void test() { Stack s = new Stack(5); ...

  3. Hdu 3887树状数组+模拟栈

    题目链接 Counting Offspring Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java ...

  4. Java连载19-用户输入和大括号省略

    一.联系一个if语句 public class d19_{ public static void main(String[] args) { double a = 20.2; if(a>100 ...

  5. Java从控制台接受输入字符

    创建一个类,在该类的主方法中创建Scanner扫描起来封装System类的in输入流,然后提示用户输入身份证号码,并输入身份证号码的位数. 代码如下: import java.util.Scanner ...

  6. java、C语言实现数组模拟栈

    java: public class ArrayStack { private int[] data; private int top; private int size; public ArrayS ...

  7. JavaScript数组模拟栈和队列

    *栈和队列:js中没有真正的栈和队列的类型              一切都是用数组对象模拟的 栈:只能从一端进出的数组,另一端封闭       FILO   何时使用:今后只要仅希望数组只能从一端进 ...

  8. LeetCode 155 - 最小栈 - [数组模拟栈]

    题目链接:https://leetcode-cn.com/problems/min-stack/description/ 设计一个支持 push,pop,top 操作,并能在常数时间内检索到最小元素的 ...

  9. 数据结构(3):java使用数组模拟堆栈

    堆栈原理: 数组模拟堆栈: //数组模拟栈 class ArrayStack{ //栈顶 private int top = -1; private int maxSize; private int[ ...

随机推荐

  1. java文件相关(文件追加内容、文件内容清空、文件内容读取)

    https://blog.csdn.net/xnz0616/article/details/39137177 1.文件内容追加 // 在已有的文件后面追加信息 public static void a ...

  2. CodeForces - 876C Classroom Watch (枚举)

    题意:已知n,问满足条件"x的各个数字之和+x=n"的x有几个并按升序输出. 分析: 1.n最大1e9,10位数,假设每一位都为9的话,可知x的各个数字之和最大可以贡献90. 2. ...

  3. #$d#$a什么意思

    #$d#$a什么意思 qjh.693111级分类:外语被浏览37次2013.05.12   满意答案 vgrwi 采纳率:50%12级 2013.05.13 回车换行 换成十进制就是 #13#10

  4. Golang gin开源实例——表设计

    UML Model 基本模型定义 type Model struct { ID int `gorm:"primary_key" json:"id"` Creat ...

  5. 019、Java中定义字符

    01.代码如下: package TIANPAN; /** * 此处为文档注释 * * @author 田攀 微信382477247 */ public class TestDemo { public ...

  6. 003、Java的单行注释

    代码如下: package TIANPAN; public class TestDemo { public static void main(String args[]) { // JAVA的单行注释 ...

  7. 关于list

    //问题一: List<string> list = new List<string>(); list = null; //这样写可以使用,但是当list值为null时会报未将 ...

  8. QEMU 配置网络

    背景 为了 实现 uboot 中连接上 QEMU-host 的网络. 非常奇怪,本人的 系统中 存在/dev/net/tun驱动,但是 lsmod | grep tun 却没有任何结果,所以实际上,这 ...

  9. 用四种方法将两个AJAX改为同步

    用四种方法将两个AJAX改为同步 Promise.Generator函数.yield.async/await 相关 今有一题,题目为: 现有ajax1()和ajax2(),用于快速初始化CODE1和C ...

  10. CAN分帧接收实现

    该版本程序实现了上电后先发送MACID检测功能,如果网络上有应答.则一直进行死循环,直到用户更改了本机的ID地址 才可以跳出循环体. 本单片机设置为双滤波 ,使目标地址为0X1F 实现了建立连接命令 ...