java10---点餐系统
public class OrderMsg { public static void main(String[] args) throws Exception {
/**
* 订餐人姓名、选择菜品、送餐时间、送餐地址、订单状态、总金额
* 01.创建对应的数组
* 02.数组的初始化
* 03.显示菜单
* 04.根据用户的选择进去指定的模块
*/
String[] names = new String[6]; // 订餐人姓名
String[] dishMsgs = new String[6];// 选择菜品
int[] numbers = new int[6];// 菜品份数
Date[] dates = new Date[6]; // 送餐时间
String[] times = new String[6]; // 送餐时间对应的String类型的日期
String[] addresses = new String[6];// 送餐地址
int[] states = new int[6];// 订单状态 0:已经预定 1:已经完成
double[] sumPrices = new double[6];// 总金额 // 初始化数据
names[0] = "小黑";
dishMsgs[0] = "八仙过海";
numbers[0] = 3;
dates[0] = new Date();
SimpleDateFormat sdf = new SimpleDateFormat("hh:mm:ss");
times[0] = sdf.format(dates[0]);
addresses[0] = "天堂路1号院";
states[0] = 1;
sumPrices[0] = 5000; names[1] = "小白";
dishMsgs[1] = "佛跳墙";
numbers[1] = 5;
dates[1] = new Date();
times[1] = sdf.format(dates[1]);
addresses[1] = "地域路2号院";
states[1] = 1;
sumPrices[1] = 500; // 初始化用户可以选择的菜
String[] dishNames = { "八仙过海", "佛跳墙", "松鼠鱼", "红烧带鱼", "时令蔬菜", "辣土豆丝" };
// 定义每个菜的单价
double[] prices = { 88, 78.8, 58.0, 28.5, 50, 80 };
// 定义点赞 的数组
int[] praiseNums = new int[6];
praiseNums[0] = 5;
praiseNums[1] = 10; System.out.println("***********欢迎进入《吃货联盟》点餐系统***********");
Scanner scanner = new Scanner(System.in);
int num = -1; // 如果用户输入的是0 默认返回主菜单
boolean isExit = false;// 定义一个标记 来标识 用户是否退出系统 true:退出
do {
// 显示菜单供用户选择
System.out.println("当前系统时间是:" + sdf.format(new Date()));
System.out.println("1:我要订餐");
System.out.println("2:查看餐袋");
System.out.println("3:签收订单");
System.out.println("4:删除订单");
System.out.println("5:我要点赞");
System.out.println("6:退出系统");
System.out.println("**********************");
System.out.println("请选择:");
int choose = scanner.nextInt(); // 根据用户的选择执行不同的功能
switch (choose) {
case 1:
System.out.println("************我要订餐************");
// 定义一个标记判断餐带是否已满
boolean addFlag = false;
for (int i = 0; i < names.length; i++) { // 订餐人的集合
if (names[i] == null) {
addFlag = true;
System.out.println("请输入订餐人的姓名:");
names[i] = scanner.next(); // 获取订餐人的姓名
System.out.println("您可以选择下列的菜品:");
System.out.println("序号\t\t\t菜名\t\t\t单价\t\t\t点赞数");
for (int j = 0; j < dishNames.length; j++) { // 遍历菜品
String praiseNum = (praiseNums[j] > 0) ? praiseNums[j]
+ "个赞"
: "";
System.out.println(j + 1 + "\t\t\t" + dishNames[j]
+ "\t\t\t" + prices[j] + "\t\t\t"
+ praiseNum);
}
// 用户开始点菜
System.out.println("请您选择菜品的编号:");
int chooseDishName = scanner.nextInt();
System.out.println("请您输入点餐的份数:");
int number = scanner.nextInt();
System.out.println("请您输入送餐的地址:");
String address = scanner.next();
System.out.println("请您输入送餐的时间:(时:分:秒)");
String time = scanner.next(); /**
* 根据用户的餐费 判断是否收取送餐费 大于60免送餐费
* 01.获取用户点的菜的单价
* 02.获取总金额
* 03.判断
*/
double sumPrice = prices[chooseDishName - 1] * number;
double price = (sumPrice > 60) ? 0 : 6;
System.out.println("恭喜您订餐成功!");
System.out.println("您定的菜品是:"
+ dishNames[chooseDishName - 1] + "\t" + number
+ "份");
System.out.print("餐费:" + sumPrice);
System.out.print("\t送餐费:" + price);
System.out.println("\t总费用:" + (price + sumPrice));
// 向数组中增加数据
times[i] = sdf.format(sdf.parse(time)); // 时间
addresses[i] = address; // 地址
sumPrices[i] = (sumPrice + price); // 总金额
dishMsgs[i] = dishNames[chooseDishName - 1]; // 定的菜品
states[i] = 0; // 订餐的状态
numbers[i] = number; // 份数
break;
}
}
if (!addFlag) {// 餐袋已经满了
System.out.println("餐袋已经满了");
}
break;
case 2:
System.out.println("************查看餐袋************");
/**
* 显示
* 编号 订餐人 菜品(份数) 送餐时间 送餐地址 总金额 状态
*/
System.out
.println("编号\t\t订餐人\t\t菜品(份数)\t\t送餐时间 \t\t送餐地址\t\t总金额\t\t状态\t\t点赞数量");
for (int i = 0; i < names.length; i++) {
if (names[i] != null) { // 有人订餐 的显示
String state = (states[i] == 0) ? "已经预定" : "已经完成"; // 获取状态
String time = times[i]; // 获取时间
String sumPrice = sumPrices[i] + "元"; // 总金额
String address = addresses[i]; // 地址
String dishMsg = dishMsgs[i]; // 菜品
int count = numbers[i];
System.out.println(i + 1 + "\t\t" + names[i] + "\t\t"
+ dishMsg + "(" + count + ")" + "\t\t" + time
+ " \t\t" + address + "\t\t" + sumPrice
+ "\t\t" + state + "\t\t" + praiseNums[i]);
}
}
break;
case 3:
System.out.println("************签收订单************");
/**
* 01.状态为已经完成!不需要签收
* 02.状态为已经预定!需要签收
* 03.没有指定的订单,不能签收
*/
System.out.println("请您输入需要签收的订单编号:");
int sign = scanner.nextInt();
// 定义一个标记 来判断订单是否被签收
int flag = 0;
for (int i = 0; i < names.length; i++) {
if (names[i] != null && states[i] == 0) {// 01.有订单 可以签收
states[i] = 1;// 改变状态
flag = 1;
break; // 必须退出 否则 后续的都会变成签收
} else if (names[i] != null && states[i] == 1) {// 02.有订单
flag = 2;
}
}
if (flag == 1) {
System.out.println("订单已经签收!");
} else if (flag == 2) {
System.out.println("订单不需要重复签收!");
} else {
System.out.println("没有指定的订单!请您核实!");
} break;
case 4:
System.out.println("************删除订单************");
System.out.println("请您输入需要删除的订单编号:");
int delNum = scanner.nextInt();
// 定义一个标记 来判断订单是否被签收以及是否存在
int delFlag = 0;
for (int i = 0; i < names.length; i++) {
if (names[i] != null && states[delNum - 1] == 1) { // 可以删除
// 有指定的订单
// 状态是已经完成
// 删除位置 之后的所有元素 依次前移
for (int j = delNum - 1; j < names.length - 1; j++) {
names[j] = names[j + 1]; // 订餐人
dishMsgs[j] = dishMsgs[j + 1];// 菜品
times[j] = times[j + 1];// 时间
addresses[j] = addresses[j + 1];// 地址
states[j] = states[j + 1];// 状态
numbers[j] = numbers[j + 1];// 份数
}
delFlag = 1;
break;
} else if (names[i] != null && states[i] == 0) { // 订单还没有签收
delFlag = 2;
}
}
if (delFlag == 1) {
System.out.println("订单已经被删除");
} else if (delFlag == 2) {
System.out.println("订单还没有签收 不允许删除!");
} else {
System.out.println("没有找到指定的订单!");
}
break;
case 5:
System.out.println("************我要点赞***************");
System.out.println("编号\t\t\t菜名\t\t\t价格");
for (int i = 0; i < dishNames.length; i++) { // 遍历所有的菜名
String price = prices[i] + "元"; // 获取价格
String name = dishNames[i];
System.out.println(i + 1 + "\t\t\t" + name + "\t\t\t"
+ price);
}
System.out.println("请您输入点赞的菜品编号:");
int chooseNum = scanner.nextInt();
praiseNums[chooseNum - 1]++;// 点赞数加+1
System.out.println("谢谢参与!点赞成功!");
break;
case 6:
// 退出系统
isExit = true;
break;
default:
// 退出系统
isExit = true;
break;
}
if (!isExit) { // 默认这是不退出
System.out.println("输入0返回主菜单!");
num = scanner.nextInt();
} else {
break; // 退出系统
} } while (num == 0);
System.out.println("谢谢您的光临!!!!!");
}
}
java10---点餐系统的更多相关文章
- [课程设计]Scrum 3.8 多鱼点餐系统开发进度(留言反馈系统设计)
Scrum 3.8 多鱼点餐系统开发进度(留言反馈系统设计) 1.团队名称:重案组 2.团队目标:长期经营,积累客户充分准备,伺机而行 3.团队口号:矢志不渝,追求完美 4.团队选题:餐厅到店点餐系统 ...
- [课程设计]Scrum 3.7 多鱼点餐系统开发进度(留言板选择方案)
Scrum 3.7 多鱼点餐系统开发进度(留言板选择方案) 1.团队名称:重案组 2.团队目标:长期经营,积累客户充分准备,伺机而行 3.团队口号:矢志不渝,追求完美 4.团队选题:餐厅到店点餐系统W ...
- [课程设计]Scrum 3.6 多鱼点餐系统开发进度(用户测试反馈页面构思&留言板设计)
Scrum 3.6 多鱼点餐系统开发进度(用户测试反馈页面构思&留言板设计) 1.团队名称:重案组 2.团队目标:长期经营,积累客户充分准备,伺机而行 3.团队口号:矢志不渝,追求完美 4.团 ...
- [课程设计]Scrum 3.5 多鱼点餐系统开发进度(修复Bug&美化页面)
Scrum 3.5 多鱼点餐系统开发进度(修复Bug&美化页面) 1.团队名称:重案组 2.团队目标:长期经营,积累客户充分准备,伺机而行 3.团队口号:矢志不渝,追求完美 4.团队选题:餐厅 ...
- [课程设计]Scrum 3.4 多鱼点餐系统开发进度(下单详细信息页面&会员信息页面)
Scrum 3.4 多鱼点餐系统开发进度(下单详细信息页面&会员信息页面) 1.团队名称:重案组 2.团队目标:长期经营,积累客户充分准备,伺机而行 3.团队口号:矢志不渝,追求完美 4.团队 ...
- [课程设计]Scrum 3.3 多鱼点餐系统开发进度(下单详细信息页面设计)
Scrum 3.3 多鱼点餐系统开发进度(下单详细信息页面设计) 1.团队名称:重案组 2.团队目标:长期经营,积累客户充分准备,伺机而行 3.团队口号:矢志不渝,追求完美 4.团队选题:餐厅到店点 ...
- [课程设计]Scrum 3.2 多鱼点餐系统开发进度(页面优化&下单详细信息页面)
Scrum 3.2 多鱼点餐系统开发进度(页面优化&下单详细信息页面) 1.团队名称:重案组 2.团队目标:长期经营,积累客户充分准备,伺机而行 3.团队口号:矢志不渝,追求完美 4.团队选 ...
- [课程设计]Scrum 1.6 多鱼点餐系统开发进度
[课程设计]Scrum 1.6 多鱼点餐系统开发进度(点餐页面按钮添加&修复) 1.团队名称:重案组 2.团队目标:长期经营,积累客户充分准备,伺机而行 3.团队口号:矢志不渝,追求完美 4. ...
- [课程设计]Scrum 1.7 多鱼点餐系统开发进度
[课程设计]Scrum 1.7 多鱼点餐系统开发进度(点餐菜式内容添加及美化) 1.团队名称:重案组 2.团队目标:长期经营,积累客户充分准备,伺机而行 3.团队口号:矢志不渝,追求完美 4.团队选题 ...
- [课程设计]Scrum 1.5 多鱼点餐系统开发进度
1.团队名称:重案组 2.团队目标:长期经营,积累客户充分准备,伺机而行 3.团队口号:矢志不渝,追求完美 4.团队选题:餐厅到店点餐系统WEB 5.Sprint 1时间:11.14-11.23 重案 ...
随机推荐
- html5.js让IE(包含IE6)支持HTML5元素方法
原文地址:http://blog.sina.com.cn/s/blog_62a36ec401018oqb.html html5.js让IE(包含IE6)支持HTML5元素方法 微软的最新浏览器IE8及 ...
- HDU1712:ACboy needs your help(分组背包)
题目:http://acm.hdu.edu.cn/showproblem.php?pid=1712 解释看这里:http://www.cnblogs.com/zhangmingcheng/p/3940 ...
- mapreduce数据不平衡时的处理方法
用mr处理大数据经常遇到数据不平衡的情况,这里的数据不平衡指的是,数据中有少部分key集中了大量的数据,导致其它的reduce都运行完了,只剩几个reduce在跑.这种情况一般有如下三种解决方法(原理 ...
- 移动app自动化测试
原文出处https://www.toutiao.com/i6473606106970063374/ 原文作者是今日头条的:一个字头的诞生 在此感谢原文作者的无私分享! 移动App自动化测试(一) 目前 ...
- HDU 6351 (Beautiful Now) 2018 Multi-University Training Contest 5
题意:给定数N(1<=N<=1e9),k(1<=k<=1e9),求对N的任意两位数交换至多k次能得到的最小与最大的数,每一次交换之后不能出现前导零. 因为N最多只有10位,且给 ...
- js 的一些兼容性写法
①添加事件方法 addHandler:function(element,type,handler){ if(element.addEventListener){//检测是否为DOM2级方法 ...
- flex NaN
如果该值为NaN(非数字),则返回true:否则返回false.public function isNaN(num:Number):Boolean 举例:NaN值不是int或uint数据类型的成员.f ...
- Entity FrameWork Code First 之 MVC4 数据库初始化策略用法
通过启用迁移和更新数据库可以很容易的生成一张表.但是对数据库修改之后,通过数据迁移就没那么好实现了. 这里用到数据库生成策略,进行对数据库操作: 一.3种主要数据库生成策略 1 CreateDatab ...
- samba 4.7.16 安装配置详解
系统:Centos 7.4 x64位 服务版本:samba-4.7.1.samba-client-4.7 Samba 简介 Samba 是在Linux和UNIX系统上实现SMB协议的一个免费软件,由服 ...
- 基于Bootstrap的日历控件和日期选择插件
在线演示 本地下载