03_模拟DVD
package com.entity; import java.text.SimpleDateFormat;
import java.util.Date; public class DVD {
private String name;
private boolean borrowed;
private Date borrowedTime;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Date getBorrowedTime() {
return borrowedTime;
}
public void setBorrowedTime(Date borrowedTime) {
this.borrowedTime = borrowedTime;
}
public DVD(String name, boolean borrowed, Date borrowedTime) {
super();
this.name = name;
this.setBorrowed(borrowed);
this.borrowedTime = borrowedTime;
}
public DVD() {
super();
}
public String toString(){
String status= isBorrowed()?"已借出":"可借";
String date;
if(getBorrowedTime()==null){
date="";
}else{
date=new SimpleDateFormat("yyyy-MM-dd").format(getBorrowedTime());
}
return "《"+getName()+"》\t"+status+"\t"+date;
}
public void setBorrowed(boolean borrowed) {
this.borrowed = borrowed;
}
public boolean isBorrowed() {
return borrowed;
} }
package com.entity; import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.Scanner; public class DVDManager {
private ArrayList<DVD> dvdList;
private final int price=2;//一张DVD2块钱1天
SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd");
Scanner input=new Scanner(System.in); public void setDvdList(ArrayList<DVD> dvdList) {
this.dvdList = dvdList;
} public ArrayList<DVD> getDvdList() {
return dvdList;
}
public DVDManager(){ }
public DVDManager(ArrayList<DVD> dvdList){
this.dvdList=dvdList;
}
public void initial(){
dvdList=new ArrayList<DVD>();
try {
DVD d=new DVD("罗马假日",true,sdf.parse("2013-07-01"));
DVD d2=new DVD("风声鹤唳",false,null);
DVD d3=new DVD("浪漫满屋",false,null);
dvdList.add(d);
dvdList.add(d2);
dvdList.add(d3);
} catch (ParseException e) {
e.printStackTrace();
}
} public void mainMenu(){
System.out.println("欢迎使用迷你DVD管理器");
System.out.println("-------------------------------------------------------");
System.out.println("" +
"1. 新增DVD\n" +
"2. 查看DVD\n" +
"3. 删除DVD\n" +
"4. 借出DVD\n" +
"5. 归还DVD\n" +
"6. 退出DVD");
System.out.println("-------------------------------------------------------");
System.out.print("请选择:");
input=new Scanner(System.in);
String regex="^[1-6]{1}$";
while(!input.hasNext(regex)){
input=new Scanner(System.in);
System.out.print("输入有误,请重新选择:");
}
int check_1=input.nextInt();
switch(check_1){
case 1:
addDVD();
break;
case 2:
queryAll();
break;
case 3:
deleteDVD();
break;
case 4:
borrowDVD();
break;
case 5:
lend();
break;
case 6:
System.out.println();
System.out.println("谢谢使用!");
System.exit(0);
break;
}
System.out.println("********************************");
back();
} public void back(){
System.out.print("输入0返回:");
input=new Scanner(System.in);
String regex="^0$";
while(!input.hasNext(regex)){
input=new Scanner(System.in);
System.out.print("输入有误,输入0返回:");
}
mainMenu();
}
public void queryAll(){
System.out.println("----> 查看DVD\n");
System.out.println("序号\t 名称 \t\t状态\t 借出日期");
for(int i=0;i<dvdList.size();i++){
System.out.println((i+1)+"\t"+dvdList.get(i));
}
}
public DVD findDVDByName(String name){
//DVD dvd=null; 与DVD dvd=new DVD();是有不同的
DVD dvd=null;
for(int i=0;i<dvdList.size();i++){
if(dvdList.get(i).getName().equals(name)){
dvd=dvdList.get(i);
break;
}
}
return dvd;
} public void addDVD(){//新增DVD
System.out.println("----> 新增DVD\n");
System.out.print("请输入DVD名称:");
String name=input.next();
DVD d=findDVDByName(name);
if(d!=null){
System.out.println("该DVD已经存在,不能再次添加!");
return;
}
d=new DVD(name,false,null);
dvdList.add(d);
System.out.println("新增《"+d.getName()+"》成功!");
} public void borrowDVD(){
System.out.println("----> 借出DVD\n");
System.out.print("请输入DVD名称:");
String name=input.next();
DVD d=findDVDByName(name);
if(d==null){
System.out.println("该DVD不存在,无法借出!");
return;
}else if(d.isBorrowed()){
System.out.println("不好意思,该DVD已被借出!");
}
System.out.print("请输入借书日期(年-月-日):");
String regex="\\d{4}-(([1][012])|([0][0-9]))-(([012][0-9])|([3][0]))";
while(!input.hasNext(regex)){
input=new Scanner(System.in);
System.out.print("借书日期格式有误请重新输入:");
}
Date date = null;
try {
date=sdf.parse(input.next());
} catch (ParseException e) {
e.printStackTrace();
}
int index=dvdList.indexOf(d);
d.setBorrowed(true);
d.setBorrowedTime(date);
dvdList.set(index, d);
System.out.println("借出《"+name+"》成功!");
} public void deleteDVD(){
System.out.println("----> 删除DVD\n");
System.out.print("请输入DVD名称:");
String name=input.next();
DVD d=findDVDByName(name);
if(d==null){
System.out.println("该DVD不存在,无法删除!");
return;
}else if(d.isBorrowed()){
System.out.println("该DVD已被借出,无法删除");
return;
}
dvdList.remove(d);//移除第一个,后面自动左移
System.out.println("删除《"+name+"》成功!");
} public void lend(){
System.out.println("----> 归还DVD\n");
System.out.print("请输入DVD名称:");
String name=input.next();
DVD d=findDVDByName(name);
if(d==null){
System.out.println("归还失败,该DVD不是我们店里的!");
return;
}else if(!d.isBorrowed()){
System.out.println("归还失败,该DVD已经归还,您的DVD不是我们店里的!");
return;
}
Date borrowDate = d.getBorrowedTime();
Date lendDate = null;
long spend;
System.out.print("请输入还书日期(年-月-日):");
String regex="\\d{4}-(([1][012])|([0][0-9]))-(([012][0-9])|([3][0]))";
while(true){//感觉还是玩死循环跳出爽
while(!input.hasNext(regex)){
input=new Scanner(System.in);
System.out.print("还书日期格式有误请重新输入:");
}
try {
lendDate=sdf.parse(input.next());
} catch (ParseException e) {
e.printStackTrace();
} if(lendDate.before(borrowDate)){//Date的比较前者是否在后者之前的方法
System.out.println("还书日期不可能比借出日期还早,请重新输入");
}else{
break;
}
}
spend=lendDate.getTime()-borrowDate.getTime();
int money=(int) Math.ceil(spend/(24*60*60*1000))*price;
int index=dvdList.indexOf(d);
d.setBorrowed(false);
d.setBorrowedTime(null);
dvdList.set(index, d);
System.out.println("归还成功!");
System.out.println("应付租金(元):"+money);
} }
package com.test; import com.entity.DVDManager; public class Test {
public static void main(String[] args) {
DVDManager dm=new DVDManager();
dm.initial();
dm.mainMenu();
}
}
03_模拟DVD的更多相关文章
- java模拟DVD管理器
import java.util.*;import java.text.*;class DVDSet{ String[] name = new String[50]; //名字 int[] ...
- SpringBoot系列: JdbcTemplate 事务控制
============================Spring JdbcTemplate 事务控制============================之前使用 JDBC API 操作, 经常 ...
- SpringBoot系列: JdbcTemplate 快速入门
对于一些小的项目, 我们没有必要使用MyBatis/JPA/Hibernate等重量级技术, 直接使用Spring JDBC 即可, Spring JDBC 是对 jdbc的简单封装, 很容易掌握. ...
- MySQL Sakila样本数据库
Sakila样本数据库介绍 Sakila样本数据库是MySQL官方提供的一个模拟DVD租赁信息管理的数据库,提供了一个标准模式,可作为书中例子,教程.文章.样品,等等,对学习测试来说是个不错的选择. ...
- 诸城模拟赛 dvd的逆序对
[题目描述] dvd是一个爱序列的孩子. 他对序列的热爱以至于他每天都在和序列度过 但是有一个问题他却一直没能解决 给你n,k求1~n有多少排列有恰好k个逆序对 [输入格式] 一行两个整数n,k [输 ...
- 03_天气查询_socket方式模拟_多线程方式
[简述] 要重视Socket开发,企业后台服务特长使用Socket. 1.服务端要有可持续运行能力,保证线程一致在运行 2.并发处理能力,使用多线程 [工程截图] [WeatherRunner.jav ...
- X-Plane飞行模拟资源整理一
计划开一个博客整理一下飞行仿真软件二次开发的相关内容 预计将陆续介绍X-Plane.Microsoft Flight Simulator.FlightGear三个主流飞行模拟器. 此处为目录(占坑,随 ...
- 【Java基础】【18Map集合&模拟斗D主X排和F排】
18.01_集合框架(Map集合概述和特点) A:Map接口概述 查看API可以知道: 将键映射到值的对象 一个映射不能包含重复的键 每个键最多只能映射到一个值 B:Map接口和Collection接 ...
- RHCSA-EXAM 模拟题目
参考答案:http://www.cnblogs.com/venicid/category/1088924.html 请首先按找以下要求配置考试系统: * Hostname: server0.examp ...
随机推荐
- std::tuple作为参数invoke调用函数
template<typename Function, typename Tuple, std::size_t... Index> decltype(auto) invoke_impl(F ...
- Jquery13 Ajax 进阶
学习要点: 1.加载请求 2.错误处理 3.请求全局事件 4.JSON 和 JSONP 5.jqXHR 对象 一.加载请求 在 Ajax 异步发送请求时,遇到网速较慢的情况,就会出现请求时间较长的问题 ...
- 【Swift实现代码】iOS架构模式之MVP
1.什么是MVP? MVP是模型(Model).视图(View).主持人(Presenter)的缩写,分别代表项目中3个不同的模块. 1.1 模型 (Model):负责处理数据的加载或存储 1.2 视 ...
- [CF1051F]The Shortest Statement
题目大意:给定一张$n$个点$m$条有权边的无向联通图,$q$次询问两点间的最短路 $n\le100000$,$m\le100000$,$1\le100000$,$m$-$n\le20$. 首先看到$ ...
- POJ-2418 Hardwood Species(二叉搜索树)
思路就是先将每个单词存进二叉树中,没出现一次,修改该单词所在结点的cnt++: 最后通过递归中序遍历输出结果. 思路很清晰,主要注意一下指针的使用,想一想为什么要这么用? 简单的解释就是,insert ...
- 混合开发的大趋势之一React Native与Android联调
转载请注明出处:王亟亟的大牛之路 先安利,有空我都会更,看到的好东西都会放进来:https://github.com/ddwhan0123/Useful-Open-Source-Android 公司某 ...
- JDBC连接池&DBUtils
JDBC连接池 DBCP:Apache推出的Database Connection Pool 使用步骤: > 添加jar包 commons-dbcp-1.4.jar commons-pool ...
- storm(二) 事务机制
前言 为了保证tuple的强有序和exactly-once语义,storm提供了事务机制,为每个tuple提供一个id 设计方法1 为每个tuple设置一个事务id,在数据库保存事务id和当前处理的i ...
- identityHashCode与偏向锁
hashCode 我们知道在Java中,一切对象都继承自java.lang.Object类.这个类中有一个可继承的方法叫hashCode().它在Object类中的方法签名是这样的: public n ...
- (转)SQL一次性插入大量数据
在SQL Server 中插入一条数据使用Insert语句,但是如果想要批量插入一堆数据的话,循环使用Insert不仅效率低,而且会导致SQL一系统性能问题.下面介绍SQL Server支持的两种批量 ...