使用java开发 零钱通项目,完成收益入账、消费、查看明细、退出等功能。

news/2025/3/15 1:16:36/

目录

1.项目的界面如下

2.说明及思路

3.代码

4.运行操作

5.尾语


1.项目的界面如下

2.说明及思路

本次编程通过idea完成。本人也正在进行java的学习,此文章用来记录这次完成的项目,代码之中颇有不足之处,皆因本人水平所限。

思路:

1.先新建一个包。建立一个主方法,先打印出这个整体的菜单,并通过Switch语句,进行功能选择,输入1-4实现对应的功能。

2.由于选择4是退出,这里整体运用for循环,如果选择退出,则return。

3.1-3中各个功能都需要记录当时的入账或者消费,所以我选择继承,直接创建一个Money父类,然后1继承Money,2继承1,3继承2,这样,创建一个子类对象,能调用各个类的方法,数据都存放在父类中,便于后续遍历输出。

4.对于消费,记录消费项目及金额到数组中,并判断消费金额是否小于余额,否则不能消费,然后记录下当时所剩的金额。收入入账也是这样。

3.代码

1.菜单部分

package LingQianTong;//菜单import java.util.Scanner;public class YeMian {public static void main(String[] args) {Money m = new choose3();Scanner scanner = new Scanner(System.in);for (int i = 1; i > 0; i++) {System.out.println("----------零钱通菜单----------");System.out.println("\t\t1  零钱通明细");System.out.println("\t\t2  消  费");System.out.println("\t\t3  收益入账");System.out.println("\t\t4  退  出");System.out.println("请选择(1-4):");int key = scanner.nextInt();switch (key) {case 1:choose1 m1 = (choose1) m;m1.choose1();break;case 2:choose2 m2 = (choose2) m;m2.choose2();break;case 3:choose3 m3 = (choose3) m;m3.choose3();break;case 4:choose4 m4 = new choose4();if (m4.quit() == 'y') {return;}break;default:System.out.println("请输入1-4");break;}}}
}

2.Money部分

package LingQianTong;//import com.sun.org.apache.xpath.internal.operations.String;public class Money {private double[] arr = {0.0};//记录每次收益入账金额private double nowMoney;//记录当前余额private String[] arr1 = new String[0];//记录消费项目名称private double[] arr2 = {0};//记录每次入账或者消费时,当时的余额//给每个属性设置getset方法public double[] getArr() {return arr;}public void setArr(double[] arr) {this.arr = arr;}public String[] getArr1() {return arr1;}public void setArr1(String[] arr1) {this.arr1 = arr1;}public double getNowMoney() {return nowMoney;}public double setNowMoney(double nowMoney) {//当入账时+,消费时-。实时的余额if (nowMoney < 0) {return this.nowMoney += nowMoney;} else {return this.nowMoney += nowMoney;}}public double[] getArr2() {return arr2;}public void setArr2(double[] arr2) {this.arr2 = arr2;}
}

3.功能1

package LingQianTong;public class choose1 extends Money {//明细public void choose1() {//明细方法System.out.println("----------零钱通明细----------");for (int i = 0, j = 0; i < getArr().length; i++) {//遍历输出入账或者消费的金额,及当时的余额if (i < getArr().length - 1) {if (getArr()[i + 1] > 0) {System.out.println("收益到账\t" + getArr()[i + 1] + "\t余额:" + getArr2()[i + 1]);} else if (getArr()[i + 1] < 0) {System.out.println(getArr1()[j] + "\t" + getArr()[i + 1] + "\t余额:" + getArr2()[i + 1]);j++;}}}}
}

4.功能2

package LingQianTong;//import com.sun.org.apache.xpath.internal.operations.String;import java.util.Scanner;public class choose2 extends choose1 {//消费private String name;//项目名字private double money;//项目金额Scanner scanner = new Scanner(System.in);public void choose2() {//记录消费名字,并存入数组中System.out.println("本次消费项目为:");name = scanner.next();String[] temp = new String[getArr1().length + 1];for (int i = 0; i < getArr1().length; i++) {temp[i] = getArr1()[i];}temp[getArr1().length] = name;setArr1(temp);//传入for (int j = 1; j > 0; j++) {//记录消费金额,并存入数组中,并对消费金额判断,余额能不能支撑此次消费System.out.println("本次消费金额为:");money = scanner.nextDouble();if (money > getNowMoney()) {                    //消费金额>现金时候,不能消费System.out.println("余额不足,支付失败");} else {                                        //能消费时,消费金额存入一个数组中,每消费一次,扩容数组并记录在尾部double[] temp1 = new double[getArr().length + 1];for (int i = 0; i < getArr().length; i++) {temp1[i] = getArr()[i];}temp1[getArr().length] = -money;setArr(temp1);setNowMoney((-money));//更新现金额度j = -100;//结束记录金额过程double[] temp111 = new double[getArr2().length + 1];//记录消费后此时的现金for (int i = 0; i < getArr2().length; i++) {temp111[i] = getArr2()[i];}temp111[getArr2().length] = getNowMoney();setArr2(temp111);}}}
}

5.功能3

package LingQianTong;import java.util.Scanner;public class choose3 extends choose2 {//收益入账private double getMoney;//入账金额Scanner scanner = new Scanner(System.in);public void choose3() {//对入账金额记录并存入数组,金额<=0时,输出输入有误System.out.println("本次到账金额为:");getMoney = scanner.nextDouble();if (getMoney <= 0) {System.out.println("金额输入有误");} else {                    //对入账金额进行记录double[] temp = new double[getArr().length + 1];for (int i = 0; i < getArr().length; i++) {temp[i] = getArr()[i];}setNowMoney(getMoney);temp[temp.length - 1] = getMoney;setArr(temp);double[] temp11 = new double[getArr2().length + 1];for (int i = 0; i < getArr2().length; i++) {temp11[i] = getArr2()[i];}temp11[getArr2().length] = getNowMoney();setArr2(temp11);}}
}

6.功能4

package LingQianTong;import java.util.Scanner;public class choose4 {//退出程序public char quit() {System.out.println("确定退出吗?y/n");Scanner scanner = new Scanner(System.in);char answer = scanner.next().charAt(0);if (answer == 'y') {return 'y';} else {return 'n';}}
}

4.运行操作

1.运行代码

2.存入100

3.存入1500

 

4.消费568

 

5.查询明细

 

6.退出

 

5.尾语

 如果有正在学习的小伙伴欢迎留言


http://www.ppmy.cn/news/510514.html

相关文章

还零钱

题目描述 考虑仅用1分、5分、10分、25分和50分这5种硬币支付某一个给定的金额。例如需要支付11分钱&#xff0c;有一个1分和一个10分、一个1分和两个5分、六个1分和一个5分、十一个1分这4种方式。 请写一个程序&#xff0c;计算一个给定的金额有几种支付方式。 注&#xff1a;假…

凑零钱

韩梅梅喜欢满宇宙到处逛街。现在她逛到了一家火星店里&#xff0c;发现这家店有个特别的规矩&#xff1a;你可以用任何星球的硬币付钱&#xff0c;但是绝不找零&#xff0c;当然也不能欠债。韩梅梅手边有 104枚来自各个星球的硬币&#xff0c;需要请你帮她盘算一下&#xff0c;…

XJOI1131换零钱

题目描述 一张n元人民币换成1元、2元、5元的零钱&#xff0c;编程计算共有多少种方法&#xff1f; 输入格式&#xff1a; 输入一行&#xff0c;包含一个整数 输出格式&#xff1a; 输出一行&#xff0c;包含一个整数 样例输入&#xff1a; 100 样例输出&#xff1a; 541 …

微信账单分析

科二挂了&#xff0c;六级过了&#xff0c;真是大喜大悲的一天啊&#xff0c;下午躺了一下午。 这次写的是用python来做微信账单分析&#xff0c;以我七月份的消费为例&#xff0c;进行分析。 最终达到的效果如下&#xff0c;为了避免泄露博主隐私&#xff0c;消费记录进行了打…

轻松记账 教你修改收支记录的步骤

如何记账&#xff0c;比较记账后如何修改或者删除不需要的收支明细呢&#xff1f;今天小编就给大家分享一个记账技巧 &#xff0c;下面小编演示操作步骤&#xff0c;希望能给大家带来帮助&#xff0c;一起来看看吧&#xff01; 第一步&#xff0c;运行【晨曦记账本】在软件主界…

零钱问题

有1块&#xff0c;2块&#xff0c;5块&#xff0c;10块&#xff0c;20块&#xff0c;50块&#xff0c;100块&#xff0c;200块这几种面值的货币&#xff0c;问总共有多少种组合出200块的方法&#xff1f; 循环穷举是通常首先想到的办法 int count0; int a, b, c, d, e, f, g;…

找零钱的两种方法

有时候&#xff0c;去便利店买几块钱的东西&#xff0c;但没有零钱&#xff0c;只能给他们一张100的&#xff0c;他们可能找给我一沓10块的和几枚硬币。我不喜欢这么多的零钱&#xff0c;要知道&#xff0c;钱越零散&#xff0c;散失地就越快&#xff0c;我希望找给我的零钱张数…

零钱有限制和没有限制的找零钱问题

在参加腾讯模拟考的时候&#xff0c;其中的一道编程题是找零钱的问题&#xff0c;但是零钱的数量是一定的&#xff0c;并不是无限的。而且零钱都是2的K次幂&#xff0c;1&#xff0c;2&#xff0c;4&#xff0c;8&#xff0c;16&#xff0c;….每种零钱的数量是 2&#xff0c;给…