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

Leetcode 2043简易银行交易系统

题目描述

  1. 简易银行系统
    尝试过
    中等
    相关标签
    相关企业
    提示
    你的任务是为一个很受欢迎的银行设计一款程序,以自动化执行所有传入的交易(转账,存款和取款)。银行共有 n 个账户,编号从 1 到 n 。每个账号的初始余额存储在一个下标从 0 开始的整数数组 balance 中,其中第 (i + 1) 个账户的初始余额是 balance[i] 。

请你执行所有 有效的 交易。如果满足下面全部条件,则交易 有效 :

指定的账户数量在 1 和 n 之间,且
取款或者转账需要的钱的总数 小于或者等于 账户余额。
实现 Bank 类:

Bank(long[] balance) 使用下标从 0 开始的整数数组 balance 初始化该对象。
boolean transfer(int account1, int account2, long money) 从编号为 account1 的账户向编号为 account2 的账户转帐 money 美元。如果交易成功,返回 true ,否则,返回 false 。
boolean deposit(int account, long money) 向编号为 account 的账户存款 money 美元。如果交易成功,返回 true ;否则,返回 false 。
boolean withdraw(int account, long money) 从编号为 account 的账户取款 money 美元。如果交易成功,返回 true ;否则,返回 false 。

示例:

输入:
[“Bank”, “withdraw”, “transfer”, “deposit”, “transfer”, “withdraw”]
[[[10, 100, 20, 50, 30]], [3, 10], [5, 1, 20], [5, 20], [3, 4, 15], [10, 50]]
输出:
[null, true, true, true, false, false]

解释:
Bank bank = new Bank([10, 100, 20, 50, 30]);
bank.withdraw(3, 10); // 返回 true ,账户 3 的余额是 $20 ,所以可以取款 $10 。
// 账户 3 余额为 $20 - $10 = $10 。
bank.transfer(5, 1, 20); // 返回 true ,账户 5 的余额是 $30 ,所以可以转账 $20 。
// 账户 5 的余额为 $30 - $20 = $10 ,账户 1 的余额为 $10 + $20 = $30 。
bank.deposit(5, 20); // 返回 true ,可以向账户 5 存款 $20 。
// 账户 5 的余额为 $10 + $20 = $30 。
bank.transfer(3, 4, 15); // 返回 false ,账户 3 的当前余额是 $10 。
// 所以无法转账 $15 。
bank.withdraw(10, 50); // 返回 false ,交易无效,因为账户 10 并不存在。

提示:

n == balance.length
1 <= n, account, account1, account2 <= 105
0 <= balance[i], money <= 1012
transfer, deposit, withdraw 三个函数,每个 最多调用 104 次

解题思路

已有的帐号为 1 到 n,分别对三种操作进行分析:

transfer 操作

如果要进行操作的帐号不在已有的帐号中,即 account1>n 或者 account2>n,那么交易无效。如果账号 account1 的余额小于 money,那么交易无效。交易有效时,我们将账号 account1 的余额减少 money,账号 account2 的余额增加 money。

deposit 操作

如果要进行操作的帐号不在已有的帐号中,即 account>n,那么交易无效。交易有效时,我们将账号 account 的余额增加 money。

withdraw 操作

如果要进行操作的帐号不在已有的帐号中,即 account>n,那么交易无效。如果账号 account 的余额小于 money,那么交易无效。交易有效时,我们将账号 account 的余额减少 money。

代码实现

public class Bank {Long[] balance;public Bank(long[] balance1) {this.balance = new Long[balance1.length];int i=0;for (long b:balance1) {balance[i++] = b;}}boolean transfer(int account1, int account2, long money) {  //if(account1 > balance.length || account2> balance.length) return false;if (balance[account1 - 1] < money) {return false;}balance[account1 - 1] -= money;balance[account2 - 1] += money;return true;}boolean deposit(int account, long money) {  // 同步if(account > balance.length) return false;balance[account - 1] += money;return true;}boolean withdraw(int account, long money) {   // 异步if(account > balance.length || balance[account - 1] < money) return false;balance[account - 1] -= money;return true;}
}
http://www.lryc.cn/news/390846.html

相关文章:

  • 适合职场小白的待办事项管理方法和工具
  • 相机参数与图像处理技术解析
  • Ubuntu20.04安装Prometheus监控系统
  • kafka consumer客户端消费逻辑解析
  • 打印机出现多个副本无法删除
  • FlinkSQL 开发经验分享
  • JVM原理(十二):JVM虚拟机类加载过程
  • Apipost接口测试工具的原理及应用详解(三)
  • unity里鼠标位置是否在物体上。
  • Java知识点大纲
  • 【Kafka】记录一次Kafka消费者重复消费问题
  • Android使用http加载自建服务器静态网页
  • python解耦重构,提高程序维护性
  • 深入解析 Laravel 事件系统:架构、实现与应用
  • 视频怎么制作gif动态图片?GIF制作方法分享
  • js 使用 lodash-es 检测某个值是否是函数
  • [go-zero] goctl 生成api和rpc
  • docker -run hello-world超时
  • 拓扑学习系列(8)黎曼度量曲面与高斯曲率
  • 汽车IVI中控开发入门及进阶(三十四):i.MX linux BSP
  • 【Python机器学习】算法链与管道——构建管道
  • Postman 高级用法学习
  • 从新手到高手:Scala函数式编程完全指南,Scala 访问修饰符(6)
  • IDEA 一键部署Docker
  • linux centos tomcat 不安全的HTTP请求方法
  • 深入Django(六)
  • PHP房产小程序微信小程序系统源码
  • vscode 历史便携版下载方法
  • 深入理解计算机系统 CSAPP 家庭作业8.19
  • JDBC学习(Java DataBase Connectivity)