因为用的是普通数组,所以编写的代码可能比较长,而且有的功能还比较不健全,代码如下:

0.定义数组(因为用static修饰可以不用New,比较方便,但可能比较损耗性能)

 //订餐人名字
static String [] names=new String[10];
//保存菜品
static String [] sums=new String[10];
//送餐时间
static int [] times=new int[10];
//地址
static String [] addres =new String[10];
//状态
static int [] states= new int[10];
//总金额
static double [] sumPrice=new double[10];
//点赞
static int [] upvote=new int[10];

数组

1.初始数据(因为没有用到数据库,所以只能用初始化数组)

 //初始化数据
public static void Inial() {
sums[0]="油炸脚趾盖";
sums[1]="红烧猪蹄";
sums[2]="鱼香肉丝"; sumPrice[0]=21.0;
sumPrice[1]=10.0;
sumPrice[2]=15; names[0]="本";
names[1]="本庆";
names[2]="我"; addres[0]="推动软件";
addres[1]="地狱火";
addres[2]="五道口"; states[0]=0;
states[1]=0;
states[2]=0; sumPrice[0]=21;
sumPrice[1]=50;
sumPrice[2]=15;
}

初始化数据

2.主菜单

 public static void Menu() {

         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("请选择");
String opterString=input.next();
switch (opterString) {
//订餐
case "1":
Dinner();
break;
//查看
case "2":
Show();
break;
//签收
case "3":
Sign();
break;
//删除
case "4":
delete();
break;
//点赞
case "5":
Upvote();
break;
case "6":
Exit();
break;
default:
System.out.println("没有该选项!!!");
break;
}
}

主菜单

3.订餐(因为编号不存在的菜品,不能选择)

 //订餐
public static void Dinner() {
System.out.println("***菜品展示****");
System.out.println("请输入订餐人");
String name=input.next();
System.out.println("序号"+"————————"+"菜品");
for (int i = 0; i < sums.length; i++) {
if (sums[i]!=null) {
System.out.println(i+1+""+sums[i]);
}
}
System.out.println("请输入您要点的菜品编号");
int id=input.nextInt();
id=id-1;
//System.out.println(id);
for (int j = 0; j < names.length; j++) {
if (names[j]==null) { //等于空就是没有数据
if (sums[j]==null || sums.length<id) { //数组为空 选择和下标 对比
System.out.println("没有该菜品编号,请重新选择");
Exit();
break;
}else {
System.out.println("请选择你需要的份数");
int num=input.nextInt(); System.out.println("请输入送餐时间(送餐时间是10点至20点间整点送餐:)");
int time=input.nextInt(); if (time>=20 || time<=10) {
System.out.println("时间不合法!!!");
Dinner();
return;
} System.out.println("请输入送餐地址:");
String add=input.next(); for (int i = 0; i < sums.length; i++) {
if (sums[i]!=null) {
if (i==id) {
names[i]=name;
if (num!=0) {
sumPrice[i]=sumPrice[i]*num;
}
addres[i]=add;
System.out.println(sums[i]+num+"份"+"???"+names[i]);
System.out.println(time+"点"+sumPrice[i]*num+"送餐费0.0元"+sumPrice[i]*num++);
break;
}
}
}
Exit();
}
}
} }

订餐Dinner()

4.查看

 //查看
public static void Show() {
System.out.println("*****查看餐袋*****");
System.out.println("序号"+"\t\t\t"+"订餐人"+"\t\t\t"+"菜品信息"+"\t\t\t\t"+"送餐日期"+"\t\t\t"+"地址"+"\t\t\t"+"价钱"+"\t\t\t"+"状态"+"\t\t\t"+"赞总计");
String temp= null;//ShowUtil(); //辅助方法
for (int i = 0; i <names.length ; i++) {
if (names[i]==null) {
continue;
}else {
if (states[i]==0) {
temp="已预订";
}else {
temp="已完成";
}
System.out.println(i+1+"\t\t\t"+names[i]+"\t\t\t\t"+sums[i]+"\t\t\t"+times[i]+"日"+"\t\t\t\t"+addres[i]+"\t\t\t\t"+sumPrice[i]+"\t\t\t\t"+temp+"\t\t\t\t"+upvote[i]);
}
}
Exit();
}

查看Show()

5.签收(签收挺恶心的,因为需要比较输入的和状态并且不为空的条件下)

 //签到
public static void Sign() {
System.out.println("******签到******");
System.out.println("请选择签到序号");
int num=input.nextInt();
num-=1;
for (int i = 0; i < names.length; i++) {
if (names[i]!=null) {
if (states[i]!=0) { //说明签到了
System.out.println("已经签到过!!!");
break;
}else {
if (num==i && states[i]==0 &&names[i]!=null) { //num和i对比 状态与0对比 并且不等于空
states[num]=1;
System.out.println("签到成功!!!!");
break;
}else {
System.out.println("已经签到了");
break;
}
}
}
}
Exit();
}

签到Sign()

6.删除(其实就是让数组初始化)

 //删除
public static void delete() {
System.out.println("*****删除订单****");
System.out.println("请输入要删除的订单序号:");
int oper= input.nextInt();
oper-=1;
for (int i = 0; i < names.length; i++) {
if (names[i]!=null) {
if (oper==i) { //找到了 置空
names[i]=null;
states[i]=0;
sumPrice[i]=0;
addres[i]=null;
times[i]=0;
System.out.println("删除成功!!!");
break;
}else {
System.out.println("删除失败!!!");
break;
}
}
}
Exit();
}

删除delete()

7.点赞

 //点赞
public static void Upvote() {
System.out.println("*****点赞****");
System.out.println("请输入序号");
int num=input.nextInt();
num-=num;
for (int i = 0; i < names.length; i++) {
if (names[i]!=null) {
upvote[i]+=1;
System.out.println("点赞成功!");
break;
}
}
Exit();
}

点赞Upvote()

8.退出

 //退出
public static void Exit() {
System.out.println("按0返回主菜单");
int operString=input.nextInt();
if (operString==0) {
Menu();
}else {
System.out.println("程序退出!");
}
}

退出Exit()

还是需要基础的!!!!!!!!

java基础之吃货联盟的更多相关文章

  1. java基础10 吃货联盟点餐系统

    public class OrderMsg { public static void main(String[] args) throws Exception { /** * 订餐人姓名.选择菜品.送 ...

  2. 小项目,吃货联盟,java初级小项目,源代码

    1:项目的实现效果.功能如图所示. 2:项目的源代码如下: import java.util.Scanner; /** * 吃货联盟订餐管理系统 * */ public class OrderingM ...

  3. 吃货联盟订餐系统 源代码 Java初级小项目

    咳咳,今天博主给大家写一个小的项目:吃货联盟订餐系统.博主不是大神(互联网架构师的路上ing),也是小白一个,不过是刚入门的小白^_^.项目功能也很简单:只是模拟日常的订餐流程呦,所以有错误以及功能不 ...

  4. Java 吃货联盟

    import java.util.Scanner; public class Shao {  private static final int[] dishNames = null;  private ...

  5. JAVA吃货联盟项目。

    1基础通过数组.选择结构.循环等实 现吃货联盟订餐系统. 1.我要订餐: 2.查看餐袋: 3.签收订单: 4.删除订单: 5.我要点赞: 6.退出系统: public class Doy001 { p ...

  6. java-logic====吃货联盟

    1.系统界面 2.功能一 3.查看餐袋 4.签收订单 5.删除订单 6.我要点赞 主要分在两个类中: 第一个类entity,主要的是一些共有的属性 主要代码: public class entity ...

  7. JAVA基础(代码)练习题61~90

    JAVA基础 61.设计一个方法打印数组{'a','r','g','s','e','r'}中下标为1和3的的元素 package Homework_90; /** * 设计一个方法打印数组{'a',' ...

  8. java基础练习 字符串,控制流,日历,日期等

    1,对基本控制流程的一些练习 package org.base.practice3; import org.junit.Test; /** * Created with IntelliJ IDEA. ...

  9. 微冷的雨Java基础学习手记(一)

    使用Java理解程序逻辑 之凌波微步 船舶停靠在港湾是很安全的,但这不是造船的目的 北大青鸟五道口原玉明老师出品 1.学习方法: 01.找一本好书 初始阶段不适合,可以放到第二个阶段,看到知识点时,要 ...

随机推荐

  1. Codeforces Round #506 (Div. 3)B.Creating the Contest(dp)

    B. Creating the Contest time limit per test 1 second memory limit per test 256 megabytes input stand ...

  2. Adobe AIR 代码签名证书使用指南

    Symantec,Thawte,GlobalSign 签发的代码签名证书都可以签名AIR文件.如果您还没有代码签名证书,请联系易维信(EVTrust)购买Adobe AIR 代码签名证书. 1.签名工 ...

  3. CodeForcesGym 100753K Upside down primes

    Upside down primes Time Limit: 2000ms Memory Limit: 262144KB This problem will be judged on CodeForc ...

  4. Leetcode 79.单词搜索

    单词搜索 给定一个二维网格和一个单词,找出该单词是否存在于网格中. 单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中"相邻"单元格是那些水平相邻或垂直相邻的单元格.同一个单 ...

  5. HDU 1540 区间合并线段树

    题目大意: 就是给定一堆位置,进行删除还原,最后找到 t 位置上的最大连续位置 #include <cstdio> #include <cstring> #include &l ...

  6. Spring的Java配置方式

    Java配置是Spring4.x推荐的配置方式,可以完全替代xml配置. 1     @Configuration 和 @Bean Spring的Java配置方式是通过 @Configuration ...

  7. ubuntu无法update

    ubuntu系统执行sudo apt-get update报错解决方法: 编辑源列表文件 sudo vi /etc/apt/sources.list 将原来的列表删除,添加如下内容(中科大镜像源) d ...

  8. js 最简单的实现复制到剪切板 xl_copy

    使用 npm install xl_copy // 项目中安装 import clipboard form 'xl_copy' // 引用 element.onclick = ()=>{     ...

  9. 拉普拉斯分布,高斯分布,L1 L2

    之前那篇文章里提到,L1其实是加上服从拉普拉斯分布的先验,L2是加上服从高斯分布的先验: http://www.cnblogs.com/charlesblc/p/7977732.html 那么记住拉普 ...

  10. JS实现转动随机数抽奖的特效代码

    JS实现转动随机数抽奖的特效代码 大家都玩过抽奖游戏,或者梦想抽到大奖吧.可是有没有想过抽奖游戏是怎么实现的呐?今天就给大家分享一款转动随机数抽奖的JS特效代码. 实现代码例如以下 <!Doct ...