java基础之吃货联盟
因为用的是普通数组,所以编写的代码可能比较长,而且有的功能还比较不健全,代码如下:
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基础之吃货联盟的更多相关文章
- java基础10 吃货联盟点餐系统
public class OrderMsg { public static void main(String[] args) throws Exception { /** * 订餐人姓名.选择菜品.送 ...
- 小项目,吃货联盟,java初级小项目,源代码
1:项目的实现效果.功能如图所示. 2:项目的源代码如下: import java.util.Scanner; /** * 吃货联盟订餐管理系统 * */ public class OrderingM ...
- 吃货联盟订餐系统 源代码 Java初级小项目
咳咳,今天博主给大家写一个小的项目:吃货联盟订餐系统.博主不是大神(互联网架构师的路上ing),也是小白一个,不过是刚入门的小白^_^.项目功能也很简单:只是模拟日常的订餐流程呦,所以有错误以及功能不 ...
- Java 吃货联盟
import java.util.Scanner; public class Shao { private static final int[] dishNames = null; private ...
- JAVA吃货联盟项目。
1基础通过数组.选择结构.循环等实 现吃货联盟订餐系统. 1.我要订餐: 2.查看餐袋: 3.签收订单: 4.删除订单: 5.我要点赞: 6.退出系统: public class Doy001 { p ...
- java-logic====吃货联盟
1.系统界面 2.功能一 3.查看餐袋 4.签收订单 5.删除订单 6.我要点赞 主要分在两个类中: 第一个类entity,主要的是一些共有的属性 主要代码: public class entity ...
- JAVA基础(代码)练习题61~90
JAVA基础 61.设计一个方法打印数组{'a','r','g','s','e','r'}中下标为1和3的的元素 package Homework_90; /** * 设计一个方法打印数组{'a',' ...
- java基础练习 字符串,控制流,日历,日期等
1,对基本控制流程的一些练习 package org.base.practice3; import org.junit.Test; /** * Created with IntelliJ IDEA. ...
- 微冷的雨Java基础学习手记(一)
使用Java理解程序逻辑 之凌波微步 船舶停靠在港湾是很安全的,但这不是造船的目的 北大青鸟五道口原玉明老师出品 1.学习方法: 01.找一本好书 初始阶段不适合,可以放到第二个阶段,看到知识点时,要 ...
随机推荐
- 洛谷 4251 [SCOI2015]小凸玩矩阵
[题解] 二分答案+二分图匹配. 先二分最小值Min,然后扫一遍这个矩阵,把满足a[i][j]<=Min的i,j连边,之后跑二分图匹配,如果最大匹配数大于等于n-k+1,当前的Min即是合法的. ...
- 51NOD 1277 字符串中的最大值(KMP)
>>点击进入原题测试<< 思路:用KMP优化的暴力写了一遍,超时!没有充分利用KMP中next数组的性质. 首先这个题是肯定要用到KMP算法的,然后会有一个next[]数组. ...
- MongoDB怎么快速的删除数据库数据?
我的mongodb里有10+数据库.现在需要重置这个环境,得到干净的没有数据的MongoDB.怎么快速安全的删除这些数据库数据呢? 记得首先备份你的数据库mongodump -o bakfolder ...
- hdu 1811拓扑排序+并查集(容器实现)
http://www.cnblogs.com/newpanderking/archive/2012/10/18/2729566.html #include<stdio.h> #includ ...
- hdu 1269 求连通图的模板题
#include<stdio.h> #include<string.h> #include<iostream>//只存在一个连通分量 #include<str ...
- python——正则表达式的理解
概念:又称规则表达式,常用来检索.替换符合某个规则的文本. 理解:特殊字符--------->规则---------->过滤字符串 目的:1.匹配给定的字符串,2.从字符串中过滤出我们需要 ...
- [ZJOI2009]硬币游戏
Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 920 Solved: 406[Submit][Status][Discuss] Descriptio ...
- [USACO06JAN]牛的舞会The Cow Prom Tarjan
题目描述 The N (2 <= N <= 10,000) cows are so excited: it's prom night! They are dressed in their ...
- CODEVS1222 信与信封问题 (匈牙利算法)
先做一遍匈牙利算法.对于已经匹配的边,如果删去之后还能最大匹配数增加,则不符合要求. 一遍匈牙利算法是O(n^3)的,对于每一条边做n次,每次O(n^2),总的复杂度是O(n^3). 注意:不要忘记输 ...
- linux安装java mysql tomcat 环境
安装jdk: 1. 查看系统版本 uname -a 2.查看操作系统 cat /proc/version 3.上传安装文件到指定目录 tar -zxvf jdkxxx. 4.修改配置文件 vi ...