迷你DVD管理器
import java.text.*;
import java.util.*;
class DVDSet {
String[] name=new String[50]; //定义一个DVD数组
boolean[] state=new boolean[50]; //定义DVD借出状态:true.已借出false.可借
String[] date=new String[50]; //定义借出日期
int[] count=new int[50]; //定义借出次数
} class DVDMgr {
Scanner input = new Scanner(System.in);
DVDSet dvd = new DVDSet(); // 初始化对象
boolean isJiechu = true; // 已借出是true 可借是false // 初始化三张DVD信息
public void initial() {
dvd.name[0] = "罗马假日";
dvd.state[0] = true; // 已借出
dvd.date[0] = "2007-7-1";
dvd.name[1] = "风声鹤唳";
dvd.state[1] = false; // 可借
dvd.name[2] = "浪漫满屋";
dvd.state[2] = false; // 可借
} public void startMenu() {
System.out.println("欢迎使用迷你DVD管理器");
System.out.println("--------------------------");
System.out.println("0.借出排行榜");
System.out.println("1.新增DVD");
System.out.println("2.查看DVD");
System.out.println("3.删除DVD");
System.out.println("4.借出DVD");
System.out.println("5.归还DVD");
System.out.println("6.退出");
System.out.println("---------------------------");
System.out.print("请选择:");
int choice = input.nextInt();
switch (choice) {
case 0:
list(); // 查看借出排行
break;
case 1:
add(); // 新增DVD
break;
case 2:
search(); // 查看DVD
break;
case 3:
delete(); // 删除DVD
break;
case 4:
lend(); // 借出DVD
break;
case 5:
returnDvd(); // 归还DVD
break;
case 6:
System.out.println("感谢您的使用!");
break;
default:
System.out.println("你的输入有误,请重新输入");
returnMain();
}
} public void returnMain() {
System.out.print("输入0返回:");
if (input.nextInt() == 0) {
startMenu();
} else {
System.out.println("输入错误,异常终止!");
}
} // 查看借出排行
public void list() {
String[] newname = new String[50]; // 定义新数组 显示DVD名称
int[] newcount = new int[50]; // 定义新数组 显示借出次数
for (int i = 0; i < dvd.name.length; i++) {
newname[i] = dvd.name[i];
newcount[i] = dvd.count[i];
}
for (int i = 0; i < newname.length; i++) { // 2层循环控制位置
for (int j = i + 1; j < newname.length; j++) {
if (newcount[i] > newcount[j]) {
int temp = newcount[i]; // 2次交换实现次数和名字的替换
newcount[i] = newcount[j];
newcount[j] = temp;
String temp1 = newname[i];
newname[i] = newname[j];
newname[j] = temp1;
}
}
}
System.out.println("---> 排行榜\n");
System.out.println("**************************");
System.out.println("次数\t名称");
// 逆序打印排行榜
for (int i = newname.length - 1; i >= 0; i--) {
if (newname[i] != null) {
System.out.println(newcount[i] + "\t《" + newname[i] + "》");
}
}
System.out.println("**************************");
returnMain();
} // 新增DVD
public void add() {
System.out.println("--->新增DVD\n");
System.out.print("请输入DVD的名称:");
String name = input.next();
for (int i = 0; i < dvd.name.length; i++) {
if (dvd.name[i] == null) { // 判断位置是否为空
dvd.name[i] = name;
dvd.state[i] = false; // 新增的光盘是可借的
System.out.println("新增《" + name + "》成功");
break;
}
}
System.out.println("**************************");
returnMain();
} // 查看DVD
public void search() {
System.out.println("--->查看DVD\n");
System.out.println("序号\t状态\t名称\t\t借出日期");
for (int i = 0; i < dvd.name.length; i++) {
if (dvd.name[i] == null) {
break;
} else if (dvd.state[i] == true) {
System.out.println((i + 1) + "\t已借出\t《" + dvd.name[i] + "》\t"
+ dvd.date[i]);
} else if (dvd.state[i] == false) {
System.out.println((i + 1) + "\t可借\t《" + dvd.name[i] + "》");
}
}
System.out.println("**************************");
returnMain();
} // 删除DVD
public void delete() {
System.out.println("--->删除DVD\n");
System.out.print("请输入DVD的名称:");
String name = input.next();
boolean flag = false;
for (int i = 0; i < dvd.name.length; i++) {
if (dvd.name[i] != null && dvd.name[i].equalsIgnoreCase(name)
&& dvd.state[i] == false) {
int j = i;
while (dvd.name[j + 1] != null) {
dvd.name[j] = dvd.name[j + 1]; // 删除元素,元素前移
dvd.state[j] = dvd.state[j + 1];
dvd.date[j] = dvd.date[j + 1];
j++;
}
// 最后一个不为空的元素置空
dvd.name[j] = null;
dvd.date[j] = null;
System.out.println("删除《" + name + "》成功!");
flag = true; // 标识位
break;
} else if (dvd.name[i] != null
&& dvd.name[i].equalsIgnoreCase(name)
&& dvd.state[i] == true) {
System.out.println("《" + name + "》为借出状态,不能删除!");
flag = true;
break;
}
if (flag == true) {
System.out.println("没有找到匹配信息");
}
}
System.out.println("**************************");
returnMain();
} // 借出DVD
public void lend() {
System.out.println("--->借出DVD\n");
System.out.print("请输入DVD的名称:");
String name = input.next();
for (int i = 0; i < dvd.name.length; i++) {
if (dvd.name[i] == null) {
System.out.println("没有找到匹配信息!");
break;
} else if (dvd.name[i].equals(name) && dvd.state[i] == false) {
System.out.print("请输入借出日期(年-月-日):");
dvd.date[i] = input.next();
System.out.println("《" + name + "》借出成功");
dvd.state[i] = true;
dvd.count[i]++;
break;
} else if (dvd.name[i].equals(name) && dvd.state[i] == true) {
System.out.println("不好意思,《" + name + "》已被借出!");
break;
}
}
System.out.println("**************************");
returnMain();
} // 归还DVD
public void returnDvd() {
System.out.println("--->归还DVD\n");
System.out.print("请输入DVD名称:");
String name = input.next();
long loan = 0; // 租金
for (int i = 0; i < dvd.name.length; i++) {
if (dvd.name[i] == null) {
System.out.println("没有找到匹配信息!");
break;
} else if (dvd.name[i].equals(name) && dvd.state[i] == true) {
System.out.print("请输入归还日期(年-月-日):");
String redate = input.next();
loan = charge(dvd.date[i], redate);
System.out.println("\n《" + name + "》归还成功");
dvd.state[i] = false;
System.out.println("借出日期为:" + dvd.date[i]);
System.out.println("归还日期为:" + redate);
System.out.println("应付租金(元):" + loan);
break;
} else if (dvd.name[i].equals(name) && dvd.state[i] == false) {
System.out.println("《" + name + "》没有被借出,无法进行归还操作!");
break;
}
}
System.out.println("**************************");
returnMain();
} // 计算日期差
public long charge(String dstr1, String dstr2) {
long charge = 0;
SimpleDateFormat sd = new SimpleDateFormat("yyyy-MM-dd"); // 格式化日期
try {
Date d1 = sd.parse(dstr1);
Date d2 = sd.parse(dstr2);
charge = (d2.getTime() - d1.getTime()) / (24 * 60 * 60 * 1000);
} catch (ParseException e) {
e.printStackTrace();
}
return charge;
}
} class Demo { public static void main(String[] args) { DVDMgr dm=new DVDMgr();
dm.initial();
dm.startMenu();
} }
迷你DVD管理器,实现DVD碟片的管理,主要包括如下功能。
1.新增DVD
2.查看DVD
3.删除DVD
4借出DVD
5.归还DVD
迷你DVD管理器的更多相关文章
- 迷你DVD管理器项目
package chapter5; import java.util.*; public class MiniDVD { public static void main(String[] args){ ...
- java 迷你DVD管理器
1.DvdSet类 package dvd_01; /** * 定义dvd的一些属性 * @author Administrator * */ public class DvdSet { String ...
- 迷你DVD管理器(Java版)
import java.text.SimpleDateFormat;import java.util.Date;import java.util.Scanner;class Test { pub ...
- DVD管理器集合版
利用所学的集合写出的DVD管理系统,运用到了所学到集合基础. import java.text.ParseException; import java.text.SimpleDateFormat; i ...
- 运用集合来做一个DVD管理器(全代码)
package DVD;import java.text.ParseException;import java.text.SimpleDateFormat;import java.util.Array ...
- java模拟DVD管理器
import java.util.*;import java.text.*;class DVDSet{ String[] name = new String[50]; //名字 int[] ...
- 控制台输出<迷你DVD管理>
使用顺序.选择.循环.跳转语句 数组 功能实现菜单显示和切换 输入的数字不符合要求直接退出程序 用户可以选择新增.查看. 删除.借出.归还.退出 思路分析 使用switch语句实现菜单选择 使用do- ...
- JAVA基础代码分享--DVD管理
问题描述 为某音像店开发一个迷你DVD管理器,最多可存6张DVD,实现碟片的管理. 管理器具备的功能主要有: 1.查看DVD信息. 菜单选择查看功能,展示DVD的信息. 2.新增DVD信息 选择新增功 ...
- java基础<迷你DVD系统>
一.写在main方法中 import java.util.*; public class MyDVDMgr { public static void main(String[] args){ Scan ...
随机推荐
- linux线程同步(3)-读写锁
一.概述 读写锁与互斥量的功能类似,对临界区的共享资源进行保护!互斥量一次只让一个线程进入临界区, ...
- 理解 OpenStack + Ceph (2):Ceph 的物理和逻辑结构 [Ceph Architecture]
本系列文章会深入研究 Ceph 以及 Ceph 和 OpenStack 的集成: (1)安装和部署 (2)Ceph RBD 接口和工具 (3)Ceph 物理和逻辑结构 (4)Ceph 的基础数据结构 ...
- 用CSS开启硬件加速来提高网站性能(转)
翻译文章,原文地址:http://blog.teamtreehouse.com/increase-your-sites-performance-with-hardware-accelerated-cs ...
- Unity 5 WebGL vs Web Player
起原 Unity5.3中看到Web Player未来将到被取消,根据Unity官方blog中称Unity5.4中将会移除web player. 本文从我知道的知识比较一下webPlayer和WebGL ...
- 什么是UV?
转自http://www.cnblogs.com/jenry/p/4083415.html 1.什么是UV? 对于三维模型,有两个最重要的坐标系统,一是顶点的位置(X,Y,Z)坐标,另一个就是UV ...
- Docker 总结(转载)
原文链接:http://blog.tankywoo.com/docker/2014/05/08/docker-4-summary.html 查看docker的子命令,直接敲docker或完整的dock ...
- PAT 1027. 打印沙漏(20)
本题要求你写个程序把给定的符号打印成沙漏的形状.例如给定17个"*",要求按下列格式打印 ***** *** * *** ***** 所谓"沙漏形状",是指每行 ...
- http://www.cnblogs.com/figure9/p/developer-reading-list.html
http://www.cnblogs.com/figure9/p/developer-reading-list.html
- codevs 1033 蚯蚓的游戏问题
Description 在一块梯形田地上,一群蚯蚓在做收集食物游戏.蚯蚓们把梯形田地上的食物堆积整理如下: a(1,1) a(1,2)…a(1,m) a(2,1) a(2,2) a(2,3)…a ...
- Tree Traversals
Tree Traversals 原题链接 常见的二叉树遍历的题目,根据后序遍历和中序遍历求层次遍历. 通过后序遍历和中序遍历建立起一棵二叉树,然后层序遍历一下,主要难点在于树的建立,通过中序遍历和后序 ...