Java连载69-接受输入、用数组模拟栈
一、编写一个酒店管理系统
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-接受输入、用数组模拟栈的更多相关文章
- 数组模拟栈(C语言)
用数组模拟栈的实现: #include <stdio.h> #include <stdlib.h> #define STACK_SIZE 100 typedef struct ...
- Java数组模拟栈
一.概述 注意:模拟战还可以用链表 二.代码 public class ArrayStack { @Test public void test() { Stack s = new Stack(5); ...
- Hdu 3887树状数组+模拟栈
题目链接 Counting Offspring Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java ...
- Java连载19-用户输入和大括号省略
一.联系一个if语句 public class d19_{ public static void main(String[] args) { double a = 20.2; if(a>100 ...
- Java从控制台接受输入字符
创建一个类,在该类的主方法中创建Scanner扫描起来封装System类的in输入流,然后提示用户输入身份证号码,并输入身份证号码的位数. 代码如下: import java.util.Scanner ...
- java、C语言实现数组模拟栈
java: public class ArrayStack { private int[] data; private int top; private int size; public ArrayS ...
- JavaScript数组模拟栈和队列
*栈和队列:js中没有真正的栈和队列的类型 一切都是用数组对象模拟的 栈:只能从一端进出的数组,另一端封闭 FILO 何时使用:今后只要仅希望数组只能从一端进 ...
- LeetCode 155 - 最小栈 - [数组模拟栈]
题目链接:https://leetcode-cn.com/problems/min-stack/description/ 设计一个支持 push,pop,top 操作,并能在常数时间内检索到最小元素的 ...
- 数据结构(3):java使用数组模拟堆栈
堆栈原理: 数组模拟堆栈: //数组模拟栈 class ArrayStack{ //栈顶 private int top = -1; private int maxSize; private int[ ...
随机推荐
- Python栈溢出【新手必学】
python3.5.4 递归函数最恶心的时候莫非栈溢出(Stack overflow).PS:另外很多人在学习Python的过程中,往往因为没有好的教程或者没人指导从而导致自己容易放弃,为此我建了个P ...
- Python 动态从文件中导入类或函数的方法
假设模块文件名是data_used_to_test.py,放在tests文件夹下 文件夹结构如下: project |-tests |-data_used_to_test.py 文件内包含一个test ...
- docker-compose 修改zabbix images 添加微信报警插件 时间同步 中文乱码 添加grafana美化zabbix
我们先来看一下我们要修改得 zabbix.yaml github https://github.com/bboysoulcn/awesome-dockercompose ve ...
- SQL statement ignored
存储过程语句错误,字段或变量名可能拼错,导致存储过程无法执行. 解决办法:仔细检查存储过程里的变量,字段,语句等是否正确.
- bzoj 1138: [POI2009]Baj 最短回文路
额,,貌似网上的题解都说超时之类的. 然而我这个辣鸡在做的时候不知道在想什么,连超时的都不会. 超时的大概是这样的,f[x][y]表示x到y的最短回文路,然后更新的话就是 f[x][y]更新到 f[a ...
- openCV 3.4 windows下的配置说明
链接: https://pan.baidu.com/s/1dkS_G8ZSBD8EnhYeEFZxhQ 密码: xu99 (从官网下的, 但360会提示有毒, 哈哈哈) 运行exe, 解压openCV ...
- 007.Oracle数据库 , 使用%进行模糊查询
/*Oracle数据库查询日期在两者之间*/ SELECT PKID, OCCUR_DATE, ATA FROM LM_FAULT WHERE ( ( OCCUR_DATE >= to_date ...
- numpy.linspace使用详解
numpy.linspace(start, stop, num=50, endpoint=True, retstep=False, dtype=None) 在指定的间隔内返回均匀间隔的数字. 返回nu ...
- mpvue + Vant weapp + 微信云服务 打造小程序应用
写在前面的话: 从事小程序开发已经大半年的时间了,但是一直都是再用原生写项目.一直想着用框架自己写一个小程序,但苦于一直没有时间.正好最近项目搁置,有了空闲时间,就研究了下mpvue + Vant w ...
- centos yum安装redis,nginx
先安装源 yum install epel-release 之后 分别安装redis,nginx