蓝桥杯全排列扩展(找零钱问题-java详解)

题目:

有n个人正在饭堂排队买海北鸡饭。每份海北鸡饭要25元。奇怪的是,每个人手里只有一张钞票(每张钞票的面值为25、50、100元),而且饭堂阿姨一开始没有任何零钱。请问饭堂阿姨能否给所有人找零(假设饭堂阿姨足够聪明)输入格式第一行一个整数n,表示排队的人数。

接下来n个整数a[1],a[2],…,a[n]。a[i]表示第i位学生手里钞票的价值(i越小,在队伍里越靠前)
  输出格式:
  输出YES或者NO
  样例输入
  4
  25 25 50
  样例输出:
  YES

整体思路

很显然,这道题是想用回溯的方式来求,如何把客人的钱取出来再找回去,事情先不用这么复杂,我们就先考虑,如果给一串数字,能不能取出其中的数字的和来等于要找的零钱,比如说25,25,50这一串数字,要找50块钱,其中满足条件的有{25,25},{50}如果能找出这两串数字,那么我们基本上就已经完成这道题目了。
 步骤一:
 和之前的全排列一样,我们先有一个排列组合的意识,之前全排列只是要求把所有的数字举出来,那么我们只需要在他们全排列运算的途中加一下,并且返回出口不再是选择数字的长度等于待排列的数字,而是满足取出数字的和等于、大于、小于目标数的情况,如果等于,那么就选好这串数字,然后返回,如果大于,那么就移除最后一个数字再返回,如果小于就继续把数字加进去
 代码如下:

public class money {
//建立一个存储放满足条件的数字的容器
static ArrayList<String> store = new ArrayList();
//定义一个最大值,如果最大值是符合条件的 那必然符合
static int max = 0;List<Integer> w = Arrays.asList(25, 25, 50);//暂时有一个测试串/*selected:暂时存储容器 choose:待选择容器 to:排序重复的筛选 flag:目标数字*/public static void run(List<Integer> choose, ArrayList<Integer> selected, ArrayList<Integer> to, int flag) {int count = selected.stream().mapToInt(Integer::intValue).sum();//Integer容器的求和方式
if (count == flag) {max = Math.max(max, count);//如果相等,max就是我们要的,并且我们希望把不重复的selected里面的内容先存起来
if(store.contains((Arrays.toString(selected.toArray())))==false) {store.add(Arrays.toString(selected.toArray()));}return;}/*如果是大于的话,我们就删掉最后一个,当没加入最后那个数字*/else if (count > flag) {selected.remove(selected.size() - 1);count = selected.stream().mapToInt(Integer::intValue).sum();max = Math.max(max, count);return;}/*其余情况我们就继续递归*/else {max = Math.max(max, count);}}
}

步骤二:
接下来就和全排列几乎一样,遍历待排列的数字,然后进行回溯
代码补充:

public class money {static ArrayList<String> store = new ArrayList();static int max = 0;List<Integer> w = Arrays.asList(25, 25, 50);public static void run(List<Integer> choose, ArrayList<Integer> selected, ArrayList<Integer> to, int flag) {int count = selected.stream().mapToInt(Integer::intValue).sum();if (count == flag) {if(store.contains((Arrays.toString(selected.toArray())))==false) {store.add(Arrays.toString(selected.toArray()));}max = Math.max(max, count);return;} else if (count > flag) {selected.remove(selected.size() - 1);count = selected.stream().mapToInt(Integer::intValue).sum();max = Math.max(max, count);return;} else {max = Math.max(max, count);}//回溯代码几乎和全排列一模一样for(int i=0;i<choose.size();i++) {Integer num = choose.get(i);Integer a = i; if(to.contains(a)) {continue;}to.add(a);selected.add(num);run(choose,selected,to,flag);to.remove(a);selected.remove(num);}}
}

步骤三:
在步骤三之前,我们先测试一下代码是否可以把满足条件的selected都存入到store容器当中,也就是50能有那些组合

public static void main(String[] args) {ArrayList<Integer> selected = new ArrayList(); ArrayList<Integer> to = new ArrayList(); run(w,selected,to,50);System.out.println(store);}

在这里插入图片描述

测试还算是比较ok的,接下来就是处理字符串的问题,现在假设我们能够拿到{25,25}{50}的话,然后我们要找钱,肯定希望把50的先找出去,所以我们需要先拿到一串数字由大到小排列
然后拿到最后一串数字,必然是整钱更多,把这些钱找出去就行了
现在我们的目标就是转化store的字符串,并且拿到最后一个字符串,转为数字

//存储最后那一串转化成int类型的容器
static ArrayList <Integer> last = new ArrayList();public static void trans(ArrayList <String> goal) {//如果goal里面是空,说明没有数字满足找钱,直接返回,找钱失败if(goal.size()==0) {return;}//因为前面要把[]去掉,会出现空格,现在把空格也去掉String fah = goal.get(goal.size()-1).replaceAll(" ","");String a [];a = fah.split(",");//以“,”为分割符 分割数字//把数字存入到之前我们准备好的容器当中即可for(int i=0;i<a.length;i++) {int das = Integer.parseInt(a[i]);last.add(das);}return ;}

测试之后可以发现,我们可以提取出存取进去的最后一串字符的数字,接下来我们就是写主函数,那我们就是循环人数,然后一个一个人的钱试,全部能找完,就YES,中途有人找不了就NO。
主函数:

 public static void main(String[] args) throws IOException{//我用的是Sacnner和io流两种方式来读取键盘内容BufferedReader iln = new BufferedReader(new InputStreamReader(System.in));//建立两个容器之前已经说过了 ArrayList <Integer> selected  = new ArrayList();ArrayList <Integer> to  = new ArrayList();//w容器是拿来存储待排列数字的,一个一个遍历List <Integer> w = new ArrayList();;/*有问题就一步一步测试,看起来会更清楚*/
//  run(w,selected,to,flag);
//  System.out.println(max);
//  System.out.println(store);
//  trans(store);
//  System.out.println(last);Scanner in = new Scanner(System.in);//读取要几个人买int ui = in.nextInt();//存储i的值,方便后面好判断是否遍历完了所有的人int nas = 0;//读取每一个人的钱String h = iln.readLine();String [] da = new String [ui];da = h.split(" ");
//开始遍历每一个人手里的钱for(int i=0;i<ui;i++) {int pi = Integer.parseInt(da[i]);w.add(pi);//不管怎样先把钱放在手里//如果是25块钱就直接收入囊中,直接跳过找钱if(pi==25) {continue;}//其他情况就先找到给我的钱-25,看看我剩下的钱有没有可以凑到的run(w,selected,to,pi-25);trans(store);//如果凑不到就直接Noifa(max!=pi-25) {System.out.println("NO");break;}//如果能找开,就把我们之前trans出来的数字,把w里面有的删掉,说明这个钱找出去了
for(int k=0;k<last.size();k++) {w.remove(last.get(k));}//last容器全清空,为下一次找钱做准备for(int k=0;k<last.size();k++) {last.remove(last.get(k));}//max也清零,等下一次的maxmax = 0;//找到i的值,如果i都遍历了,说明都能找钱,后续就是输出YESnas = i;}if(nas==ui-1) {System.out.println("YES");}}

总结:

整道题目就完成了,总体思路还是比较容易想,回溯思路就可以完成找钱的步骤,难度还算比较大吧!

PS:因为没有测试器测试,我觉得肯定有些逻辑小错误,有什么问题可以及时评论,谢谢喔!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/28524.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

想搞钱,先培养商业思维!

昨天谈借助 ChatGPT 挣点房贷钱的时候&#xff0c;看评论区大家留言的时候&#xff0c;发现很多人不知道这个东西可以赚钱&#xff0c;或者说知道这个东西且也做了功课&#xff0c;无奈太忙最后也没搞到钱。 可以看到&#xff0c;大家的问题&#xff0c;归根于自己有没有商业思…

马云获聘香港大学荣誉教授;马斯克预计 2 个月内再次尝试发射星舰;​Rust 1.69.0 发布|极客头条...

「极客头条」—— 技术人员的新闻圈&#xff01; CSDN 的读者朋友们早上好哇&#xff0c;「极客头条」来啦&#xff0c;快来看今天都有哪些值得我们技术人关注的重要新闻吧。 整理 | 梦依丹 出品 | CSDN&#xff08;ID&#xff1a;CSDNnews&#xff09; 一分钟速览新闻点&#…

中科院发布多模态 ChatGPT,图片、语言、视频都可以 Chat ?中文多模态大模型力作...

进NLP群—>加入NLP交流群 夕小瑶科技说 原创作者 | 小戏、ZenMoore在 GPT-4 的发布报道上&#xff0c; GPT-4 的多模态能力让人印象深刻&#xff0c;它可以理解图片内容给出图片描述&#xff0c;甚至能在图片内容的基础上理解其中的隐喻或推断下一时刻的发展。 无疑&#xf…

有没有哪个瞬间,让你突然对ChatGPT感到失望? | AIGC实践

不知道你是否和我一样&#xff0c;在第一次使用ChatGPT输入Prompt&#xff0c;并得到答复的那一刻&#xff0c;都会忍不住地赞叹一句&#xff1a;握草。 但随着时间慢慢拉长&#xff0c;体验不断深入&#xff0c;想法也会慢慢改变…… 主题图 by Midjourney。Prompt&#xff1a…

Linux系统调用(2.哈工大OS实验二)

Linux系统调用与哈工大实验二 实验要求 此次实验的基本内容是&#xff1a;在Linux 0.11上添加两个系统调用&#xff0c;并编写两个简单的应用程序测试它们。 具体实验细节可以参考蓝桥云&#xff1a; https://www.lanqiao.cn/courses/115/learning/?id374&compatibility…

排好队,一个一个来:宫本武藏教你学队列(附各种队列源码)

文章目录 前言&#xff1a;理解“队列”的正确姿势一个关于队列的小思考——请求处理队列的两大“护法”————顺序队列和链式队列数组实现的队列链表实现的队列 循环队列关于开篇&#xff0c;你明白了吗&#xff1f;最后说一句 前言&#xff1a; 哈喽&#xff01;欢迎来到黑…

分享几个线上副业!!

线上副业 有哪些可以在线上运作就能赚取生活费的方式&#xff1f; 我这个暑假没有去打暑假工&#xff0c;因为疫情原因&#xff0c;一直待在家里&#xff0c;没有收入就不能出去玩&#xff0c;不能买漂亮衣服&#xff0c;就开始了一系列的线上兼职寻找&#xff0c;到处碰壁&…

学会Python如何去变现?副业月收入10000+了解一下

自学 Python 之后如果不去公司上班&#xff0c;自己一个人可以通过此技能挣什么钱&#xff1f; 逆天的Python&#xff0c;只要你掌握了相关技术&#xff0c;就可以靠它赚钱&#xff0c;具体怎么赚&#xff0c;我们来看看一位小哥哥的回答。 以我差不多四年的 Python 使用经验…

悟空问答赚钱副业项目,操作的好可月入10000+

我不知道你是否做过这种项目。这也是自媒体。如果你没有&#xff0c;你可以试试。收入不错。 有人可能会说悟空问答已经过时了。事实上&#xff0c;悟空问答每天仍能挣300元。好吧&#xff0c;我们已经取得了经验&#xff0c;在这里我们也与大家分享。 基本上&#xff0c;每个…

ChatGPT:编写一个带UI界面的计算器

代码&#xff1a; import tkinter as tkclass Calculator:def __init__(self, master):self.master mastermaster.title("Calculator")self.total tk.StringVar()self.entered_number tk.StringVar()self.entered_number.set(0)self.total.set(0)self.entry tk.…

使用Java进行编曲

一、编曲部分 1.1一丢丢乐理知识 简单普及下乐理哈&#xff0c;这样便于读谱 钢琴谱一行分两个部分 上面一行用右手弹(主奏)&#xff1b; 下面一行用左手弹奏(伴奏)。 1.2 关于节奏 &#xff08;1&#xff09;、主奏与伴奏中支持输入的35个音符&#xff1a; 倍低音&#…

小米系列手机(包括红米,黑鲨)开启调试模式

1. 点击我的设备 进入设置主页面&#xff0c;点击我的设备&#xff0c;点击全部参数。 2. 点击MIUI版本 连续点击MIUI版本直到出现提示&#xff0c;开发者权限已开启。 3. 点击更多设置 返回设置&#xff0c;点击更多设置。 4. 查看信息 在更多设置中就能看到开发者选项。 …

小米手机超越苹果,成欧洲第二;马斯克特斯拉内部邮件:痛恨开会,少讲黑话;Spring 6.0 发布|极客头条...

「极客头条」—— 技术人员的新闻圈&#xff01; CSDN 的读者朋友们早上好哇&#xff0c;「极客头条」来啦&#xff0c;快来看今天都有哪些值得我们技术人关注的重要新闻吧。 整理 | 梦依丹 出品 | CSDN&#xff08;ID&#xff1a;CSDNnews&#xff09; 一分钟速览新闻点&#…

MiPush四种推送对象

文档中心 推送对象目前支持四种&#xff1a;RegID、别名、userAccount、标签。 RegID&#xff1a;针对单一设备推送消息。应用调用MiPushClient类的静态方法registerPush注册小米推送服务&#xff0c;注册的结果将通过PushMessageReceiver继承类的onCommandResult方法和onRec…

小米正式宣布:这种手机以后买不到了…

开头先问大家一个问题&#xff0c;你的手机屏幕尺寸是多少&#xff1f; 还记得当初乔老爷子发布 iPhone 时&#xff0c;称 3.5 英寸是人手握持的最佳尺寸。 不过&#xff0c;当时苹果显然没有考虑到奥尼尔这样体格魁梧的人的使用感受... 3.5 英寸&#xff0c;4.0 英寸&#xf…

MIUI金凡回应用户反馈小米手机发热情况

本文转载自IT之家 IT之家 6 月 17 日消息 小米产品总监、MIUI 体验总负责人金凡近期称&#xff0c;已正式成立了“MIUI 先锋小组”&#xff0c;集中解决大家反馈的各类体验问题&#xff0c;做好首席客服小组。接下来会以报告的形式将工作进度发在小米社区中&#xff0c;请大家…

原来这样可以优雅地解决小米手机后台弹窗权限问题

/ 今日科技快讯 / 7月23日&#xff0c;据外媒报道&#xff0c;微软宣布将向总部位于美国旧金山的人工智能研究公司OpenAI投资10亿美元&#xff0c;为其云计算平台开发AI技术。 / 作者简介 / 本篇文章转载自nodzhang的博客&#xff0c;分享了他对于小米手机后台弹出界面…

时薪15美元的ChatGPT外包工人,干的都是苦力活

整理 | 朱珂欣 出品 | CSDN程序人生&#xff08;ID&#xff1a;coder_life&#xff09; 自 ChatGPT 去年 11 月发布以来&#xff0c;让不少打工人陷入担心失业的恐慌中&#xff0c;也解决了部分人的“就业问题”。 34 岁的 Alexej Savreux &#xff0c;就是其中之一。 作为 …

AutoGPT:全自动的人工智能助手

让 GPT-4 为你实现一切&#xff01; 随着人工智能技术的飞速发展&#xff0c;GPT-4 作为强大的人工智能语言模型成为了众多应用场景的核心。今天&#xff0c;我们将为你揭秘一款具有革命性意义的 GPT-4 应用——AutoGPT&#xff01;一款让你轻松操控 GPT-4&#xff0c;实现各种…

文心一言、GPT3.5及GPT4的应用测评对比

省时查报告-专业、及时、全面的行研报告库 省时查方案-专业、及时、全面的营销策划方案库 【免费下载】2023年2月份热门报告合集 最新亲测国内可用ChatGPT使用教程&#xff08;3分钟搞定&#xff09; ChatGPT团队背景研究报告 ChatGPT的发展历程、原理、技术架构及未来方向 Cha…