贪心策略解凑零问题--Java实现程序可视化(算法设计大作业)

一、运行截图

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

二、代码

package Last_Homework;

import java.net.MalformedURLException;
import java.net.URL;
import javax.swing.ImageIcon;
import javax.swing.JOptionPane;
import com.sun.prism.Graphics;
import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.control.Label;
import javafx.scene.control.PasswordField;
import javafx.scene.control.TextField;
import javafx.scene.image.ImageView;
import javafx.scene.layout.GridPane;
import javafx.scene.layout.HBox;
import javafx.scene.layout.Pane;
import javafx.scene.layout.StackPane;
import javafx.scene.paint.Color;
import javafx.scene.shape.Circle;
import javafx.geometry.Insets;
import javafx.geometry.Pos;
import javafx.stage.Stage;
import javafx.scene.text.Text;
import javafx.scene.text.Font;
import javafx.scene.text.FontWeight;
import javafx.scene.text.FontPosture;


public class coin extends Application
{
	// 窗口设置
	public void start(Stage ps) throws MalformedURLException 
	{
		Scene scene=new Scene(userPane(),400,400);
		ps.setTitle("找零界面");
		ps.setScene(scene);
		ps.show();
		
	}
	
	// 主函数调用
	public static void main(String[] args) 
	{
		launch(args);		
	}
	
	// 窗口具体配件设置
	GridPane userPane() throws MalformedURLException 
	{
		
		// 用户窗口设置
		GridPane pane=new GridPane();
		
		// 编辑者组件
		ImageIcon icon;
		icon = new ImageIcon(new URL("https://www.gdufs.edu.cn/images/logo.jpg"));
		JOptionPane.showMessageDialog(null, "Edition 1.0 版\n版权所有:广东外语外贸大学信息学院", "关于Compiler", -1, icon);
		
		// 找零窗口
		pane.setAlignment(Pos.CENTER); //居中
		pane.setPadding(new Insets(11.5, 12.5, 13.5, 14.5));
		pane.setVgap(20);//上下间隔
					
		//设置付款输入框
		TextField pay = new TextField();
		pay.setPrefWidth(80.0);	// 输入框大小
		pane.add(new Label("付款:"),0, 0);
		pane.add(pay, 1,0);
				
		Button btReg = new Button("应找");
		pane.add(btReg, 3, 0);
		
		
		//定义六个面额框
		pane.add(new Label("100:"),0, 1);
		TextField O = new TextField();
		O.setPrefWidth(20.0);	// 输入框大小
		pane.add(O, 1,1);
		
		pane.add(new Label("50:"),2, 1);
		TextField T = new TextField();
		T.setPrefWidth(20.0);	// 输入框大小
		pane.add(T, 3,1);
		
		pane.add(new Label("20:"),0, 2);
		TextField F = new TextField();
		F.setPrefWidth(20.0);	// 输入框大小
		pane.add(F, 1,2);
		
		pane.add(new Label("10:"),2, 2);
		TextField S = new TextField();
		S.setPrefWidth(20.0);	// 输入框大小
		pane.add(S, 3, 2);
		
		pane.add(new Label("5:"),0, 3);
		TextField E = new TextField();
		E.setPrefWidth(20.0);	// 输入框大小
		pane.add(E, 1,3);
		
		pane.add(new Label("1:"),2, 3);
		TextField R = new TextField();
		R.setPrefWidth(20.0);	// 输入框大小
		pane.add(R, 3,3);
				
		//字体变大
		pane.setStyle("-fx-font-size: 20px;-fx-pref-width:100px;-fx-min-width: 60px;-fx-max-width: 160px;");
		
		
		//付款事件重写
		btReg.setOnAction(e->{
			
			String p = pay.getText();
			
			// 贪心算法解决找零问题
			int [] count =  {0, 0, 0, 0, 0, 0};
			int [] money =  {100, 50, 20, 10, 5, 1};
			
			int act =Integer.parseInt(p);  // 转 int
			
			for(int i = 0; i < 6; i ++)
			{
				if(act - money[i] >= 0 && act > 0)
				{
					act -= money[i];
					count[i] +=1;
					i -= 1;
				}	
			}
			
			// 结果反馈到对应文字框里
			O.setText(count[0]+"张");  // 转 String
			T.setText(count[1]+"张");
			F.setText(count[2]+"张");
			S.setText(count[3]+"张");
			E.setText(count[4]+"张");
			R.setText(count[5]+"张"); 
			
			// 控制台输出
			for(int i = 0; i < 6;i ++)
			{
				if(count[i] != 0)
				{
					System.out.print("需要  ");
					System.out.print(money[i]);
					System.out.print("  元  ");
					System.out.print(count[i]);
					System.out.println("  张");
				}
			}
			
		});
		return pane;
	}
	
}


核心思想:贪心策略实现,这里建议可以改成动态规划实现,效果更好,贪心策略有局限性,而动态规划没有局限性。

// 贪心算法解决找零问题
			int [] count =  {0, 0, 0, 0, 0, 0};
			int [] money =  {100, 50, 20, 10, 5, 1};
			
			int act =Integer.parseInt(p);  // 转 int
			
			for(int i = 0; i < 6; i ++)
			{
				if(act - money[i] >= 0 && act > 0)
				{
					act -= money[i];
					count[i] +=1;
					i -= 1;
				}	
			}

三、总结

基于本学期算法设计课,运用大一下学期学过的javaFX可视化知识和本学期大二上学的贪心策略思想将凑零问题可视化,所以分享一下,有任何疑惑以及其他方面的提问,欢迎留言~

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
用来完成大作业的。文档内容: 1 Java技术体系 1.1 Java语言 1.2 Java平台 1.3 Java应用领域 2 Java语言的技术特点 2.1 1 2.2 2 2.3 3 3 Java语言与C++的异同分析总结。 4 选用C和java语言时编程算法程序有什么不同,有什么优势和劣势。 5 自己编程学习的级别和状态。以及自己以后的编程学习的计划和想法。 6 下面3道题目中选一道,给出算法分析和程序。 1)“黄金分割数”在我们的生活中很常见,但是在不同的应用领域,要求的精度也不一样。 例如:三位小数是0.618 现在我们需要你能求出保留100位小数的黄金分割数,采用的算法为“分层计算法”: 黄金数= 1 --------------- 1+ 1 ------------- 1+ 1 ----------- 1+ 1 --------- ..... 注意,计算出的结果,如果第100位为0也需要保留。 2)已知一个数列: 5,2,4,3,7,6 那么,在这个数列中存在这样一些“连续数”,例如:5,2,4,3这个子数列排序后是连续的。同样2,4,3也是连续的,为了方便表示 我们使用下标来标识,这样,这个数列中存在以下“连续数”: [1,1] [1,4] [1,6] [2,2] [2,4] [3,3] [3,4] [4,4] [5,5] [5,6] [6,6] 这样,他就存在11个“连续数”。现在需要你在用户找出一个数组中所有的“连续数”。 要求: 1、用户输入一个整数N,表示下面数组的个数 2、用户每输入一行作为一个数组 如: 用户输入: 1 5,2,4,3,7,6 程序输出: 11 3)有一种数我们称之为幸运数,它的特点是这样的,首先,由自然数按顺序排列: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 … 这样,1比较特殊, 1为第一个幸运数,那么,我们移除掉序号能被2整除的数(注意:是序号,而不是数本身,每次移除后都重新排序)就剩下: 1 3 5 7 9 11 13 15 17 19… 3为第二个幸运数,那么我们需要去掉序号能被3(下一次是除4,然后是5,每次加1)整除的数,5 11 17...剩下: 1 3 7 9 13 15 19… 那么7为第三个幸运数,后面的幸运数,依此类推,移除之后剩下的数字都是幸运数。 现在我们需要你求出给定的m和n之间的幸运数的个数: 例如:给定1 20,那么个数为:5(5个幸运数分别是1,3,7,13,19) 现在要求用户输入两个数m和n(m<n<=1000*1000),输出幸运数的个数。 例如: 用户输入: 1 20 程序输出: 5 格式:小四,1.5倍行距
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值