当前位置: 首页 > news >正文

【算法与数据结构】860、LeetCode柠檬水找零

文章目录

  • 一、题目
  • 二、解法
  • 三、完整代码

所有的LeetCode题解索引,可以看这篇文章——【算法和数据结构】LeetCode题解。

一、题目

在这里插入图片描述

二、解法

  思路分析:本题的思路比较简单,首先要保存收到的零钱,其次计算找零,最后分解找零。程序当中for循环遍历整个数组,然后stock保存收到的零钱,change表示找零。找零一共有三种情况,其中第三种情况最特殊:

    1. 不用找零:固定
    1. 找零5元:固定
    1. 找零15元:可以分解为10+5或者5+5+5;但是我们需要优先用掉10元,因为5元更加万能,即可以找5元零钱也可以找15元零钱,而10元只能找15元的零钱。

  程序如下

class Solution {
public:bool lemonadeChange(vector<int>& bills) {// 1.计算找零 2.找零的分解vector<int> stock(4, 0);for (int i = 0; i < bills.size(); i++) {stock[bills[i] / 5 - 1]++;	int change = bills[i] - 5;if (change == 0) continue;	// 不用找钱else if (change == 5) {					// 找5元if (stock[0] < 1) return false;stock[0]--;}else{									// 找15元if (stock[1] >= 1 && stock[0] >= 1) {	// 分解成10+5,优先用10元找零stock[1]--;stock[0]--;}else if (stock[0] >= 3) stock[0] -= 3;	// 分解成5+5+5else return false;}}return true;}
}; 

复杂度分析:

  • 时间复杂度: O ( n ) O(n) O(n)
  • 空间复杂度: O ( 1 ) O(1) O(1)

三、完整代码

# include <iostream>
# include <vector>
using namespace std;class Solution {
public:bool lemonadeChange(vector<int>& bills) {// 1.计算找零 2.找零的分解vector<int> stock(4, 0);for (int i = 0; i < bills.size(); i++) {stock[bills[i] / 5 - 1]++;	int change = bills[i] - 5;if (change == 0) continue;	// 不用找钱else if (change == 5) {					// 找5元if (stock[0] < 1) return false;stock[0]--;}else{									// 找15元if (stock[1] >= 1 && stock[0] >= 1) {	// 分解成10+5,优先用10元找零stock[1]--;stock[0]--;}else if (stock[0] >= 3) stock[0] -= 3;	// 分解成5+5+5else return false;}}return true;}
}; int main() {vector<int> bills = { 5,5,5,10,20 };		// 加油站的油量Solution s1;int result = s1.lemonadeChange(bills);cout << result << endl;system("pause");return 0;
}

end

http://www.lryc.cn/news/270692.html

相关文章:

  • 「Verilog学习笔记」乘法与位运算
  • CSS与JavaScript的简单认识
  • MAC 中多显示器的设置(Parallels Desktop)
  • 迁移到云原生:如何使用微服务迁移应用程序
  • kafka 的零拷贝原理
  • 华为云Stack 8.X流量模型分析(五)
  • 学习动态规划解决不同路径、最小路径和、打家劫舍、打家劫舍iii
  • nodejs微信小程序+python+PHP特困救助供养信息管理系统-计算机毕业设计推荐
  • Vue(二):计算属性与 watch 监听器
  • 25、WEB攻防——通用漏洞SQL读写注入MYSQLMSSQLPostgreSQL
  • 【第5期】前端Vue使用Proxy+Vuex(store、mutations、actions)跨域调通本地后端接口
  • 在Visual Studio(VS)编译器中,Release和Debug区别
  • 子网划分问题(实战超详解)_主机分配地址
  • 【QT】单例模式,Q_GLOBAL_STATIC 宏的使用和使用静态成员函数,eg:{简单的日志记录器}
  • 利用小红书笔记详情API:构建高效的内容创作与运营体系
  • 【K8S 二进制部署】部署单Master Kurbernetes集群
  • vue中常见的指令
  • 单片机原理及应用:开关控制LED多种点亮模式
  • 你真的了解UVM sequence的运行机制吗
  • Bug升级记
  • 爬虫详细教程第1天
  • [Linux] MySQL数据库的备份与恢复
  • Django、Python版本升级问题大汇总
  • 2023-12-30 AIGC-LangChain介绍
  • pytorch01:概念、张量操作、线性回归与逻辑回归
  • storyBook play学习
  • Android Matrix画布Canvas旋转Rotate,Kotlin
  • 私有部署ELK,搭建自己的日志中心(三)-- Logstash的安装与使用
  • 2023就这样过去了,2024会更好吗?
  • SpringBoot加载配置的6种方式