华为OD机试 - 符号运算 - 递归(Java 2024 C卷 100分)

在这里插入图片描述

华为OD机试 2024C卷题库疯狂收录中,刷题点这里

专栏导读

本专栏收录于《华为OD机试(JAVA)真题(A卷+B卷+C卷)》。

刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,发现新题目,随时更新,全天CSDN在线答疑。

一、题目描述

给定一个表达式,求其分数计算结果

表达式的限制如下:

  1. 所有的输入数字皆为正整数(包括0)
  2. 仅支持四则运算(±*/)和括号
  3. 结果为整数或分数, 分数必须化为最简格式(比如6, 3/4, 7/8, 90/7)
  4. 除数可能为0,如果遇到这种情况,直接输出"ERROR"
  5. 输入和最终计算结果中的数字都不会超出整型范围

用例的输入一定合法, 不会出现括号不匹配的情况

二、输入描述

字符串格式的表达式,仅支持±*/,数字可能超过两位,可能带有空格,没有负数

长度小于200个字符

三、输出描述

表达式结果,以最简格式表达 如果结果为整数,那么直接输出整数 如果结果为分数,那么分子分母不可再约分,可以为假分数,不可表达为带分数 结果可能是负数, 负号放在最前面

1、输入

1 / (0-5)

2、输出

-1/5

四、解题思路

此问题需要处理一个包含四则运算和括号的数学表达式,并正确处理分数和除法。关键步骤如下:

1、解析和计算表达式:

使用递归或栈来处理括号和操作符的优先级。
支持整数和分数的四则运算。

2、处理分数:

对于每次运算结果,若为分数,则需要化简(约分)。
使用两个整数表示分数(分子和分母),并在每次运算后使用最大公约数(GCD)来约分。

3、错误处理:

当遇到除数为零的情况,立即返回"ERROR"。

4、表达式结果格式:

如果分母为1,则输出整数。
如果不为1,则输出最简分数格式。
确保分数的符号只出现在分子上。

五、Java算法源码

通过递归函数 eval() 来计算和解析包含括号的表达式。它支持基本的四则运算,并正确处理分数和整数。当除数为零时,它会捕获ArithmeticException并返回"ERROR"。

public class OdTest01 {public static void main(String[] args) {Scanner sc = new Scanner(System.in);String expression = sc.nextLine();String result = evaluate(expression);System.out.println(result);}private static String evaluate(String expression) {try {// 清除表达式中的空格expression = expression.replaceAll(" ", "");// 计算表达式结果BigInteger[] result = eval(expression, 0, expression.length());// 处理并格式化结果输出if (result[1].equals(BigInteger.ZERO)) {return "ERROR";  // 遇到除数为零} else if (result[1].equals(BigInteger.ONE)) {return result[0].toString();  // 结果为整数} else {return result[0] + "/" + result[1];  // 输出最简分数}} catch (ArithmeticException e) {return "ERROR";}}// 解析并计算表达式private static BigInteger[] eval(String s, int start, int end) {// 分子和分母BigInteger numerator = BigInteger.ZERO;BigInteger denominator = BigInteger.ONE;BigInteger currentNumerator = BigInteger.ZERO;BigInteger currentDenominator = BigInteger.ONE;char lastOp = '+';for (int i = start; i < end; i++) {char ch = s.charAt(i);if (ch >= '0' && ch <= '9') {// 数字的处理int j = i;while (j < end && Character.isDigit(s.charAt(j))) j++;currentNumerator = new BigInteger(s.substring(i, j));currentDenominator = BigInteger.ONE;i = j - 1;} else if (ch == '(') {// 括号的处理int count = 1;int j = i + 1;while (j < end && count != 0) {if (s.charAt(j) == '(') count++;if (s.charAt(j) == ')') count--;j++;}BigInteger[] res = eval(s, i + 1, j - 1);currentNumerator = res[0];currentDenominator = res[1];i = j - 1;} else if (ch == '+' || ch == '-' || ch == '*' || ch == '/') {// 运算符的处理if (lastOp == '+') {numerator = numerator.multiply(currentDenominator).add(currentNumerator.multiply(denominator));denominator = denominator.multiply(currentDenominator);} else if (lastOp == '-') {numerator = numerator.multiply(currentDenominator).subtract(currentNumerator.multiply(denominator));denominator = denominator.multiply(currentDenominator);} else if (lastOp == '*') {numerator = numerator.multiply(currentNumerator);denominator = denominator.multiply(currentDenominator);} else if (lastOp == '/') {numerator = numerator.multiply(currentDenominator);denominator = denominator.multiply(currentNumerator);}// 约分BigInteger gcd = numerator.gcd(denominator);numerator = numerator.divide(gcd);denominator = denominator.divide(gcd);// 更新最后的操作符lastOp = ch;currentNumerator = BigInteger.ZERO;currentDenominator = BigInteger.ONE;}}// 处理最后的运算符if (lastOp == '+') {numerator = numerator.multiply(currentDenominator).add(currentNumerator.multiply(denominator));denominator = denominator.multiply(currentDenominator);} else if (lastOp == '-') {numerator = numerator.multiply(currentDenominator).subtract(currentNumerator.multiply(denominator));denominator = denominator.multiply(currentDenominator);} else if (lastOp == '*') {numerator = numerator.multiply(currentNumerator);denominator = denominator.multiply(currentDenominator);} else if (lastOp == '/') {numerator = numerator.multiply(currentDenominator);denominator = denominator.multiply(currentNumerator);}// 约分BigInteger gcd = numerator.gcd(denominator);numerator = numerator.divide(gcd);denominator = denominator.divide(gcd);// 确保分母总是正数if (denominator.compareTo(BigInteger.ZERO) < 0) {denominator = denominator.negate();numerator = numerator.negate();}return new BigInteger[] {numerator, denominator};}
}

六、效果展示

1、输入

1 * (3*4/(8-(7+0)))

2、输出

12

3、说明

在这里插入图片描述


🏆下一篇:华为OD机试 - 简易内存池 - 逻辑分析(Java 2024 C卷 200分)

🏆本文收录于,华为OD机试(JAVA)真题(A卷+B卷+C卷)

刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,发现新题目,随时更新,全天CSDN在线答疑。

在这里插入图片描述

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

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

相关文章

使用 FFmpeg 从音视频中提取音频

有时候我们需要从视频文件中提取音频&#xff0c;并保存为一个单独的音频文件&#xff0c;我们可以借助 FFmpeg 来完成这个工作。 一、提取音频&#xff0c;保存为 mp3 文件: 要使用 FFmpeg 从音视频文件中提取音频&#xff0c;并将 ACC 编码的音频转换为 MP3 格式&#xff0…

CNN实现fashion_mnist数据集分类(tensorflow)

1、查看tensorflow版本 import tensorflow as tfprint(Tensorflow Version:{}.format(tf.__version__)) print(tf.config.list_physical_devices())2、加载fashion_mnist数据与预处理 import numpy as np (train_images,train_labels),(test_images,test_labels) tf.keras.d…

Neo4j+LLM+RAG 环境配置报错处理

开发KGLLMRAG程序时遇到以下报错&#xff0c;记录下处理方案&#xff1a; ValueError: Could not use APOC procedures. Please ensure the APOC plugin is installed in Neo4j and that ‘apoc.meta.data()’ is allowed in Neo4j configuration 这个参考文章&#xff1a;link…

FFmpeg学习记录(四)——SDL音视频渲染实战

1.SDL使用的基本步骤 SDL Init/sDL _Quit()SDL_CreateWindow()/SDL_DestoryWindow()SDL CreateRender() SDL_Windows *windows NULL;SDL_Init(SDL_INIT_VIDEO);window SDL_CreateWindow("SDL2 Windows",200,200, 640,480,SDL_WINDOW_SHOWN);if(!window) {printf(&…

【链表】:链表的带环问题

&#x1f381;个人主页&#xff1a;我们的五年 &#x1f50d;系列专栏&#xff1a;数据结构 &#x1f337;追光的人&#xff0c;终会万丈光芒 前言&#xff1a; 链表的带环问题在链表中是一类比较难的问题&#xff0c;它对我们的思维有一个比较高的要求&#xff0c;但是这一类…

【linux-IMX6ULL配置GPIO通用流程-以及时钟配置】

目录 1. GPIO模式控制流程1.1 LED、蜂鸣器、按键1.2 GPIO控制流程 2. 标准库的简要分析及实现&#xff1a;2.1 问题引入&#xff1a;2.2 代码实现&#xff1a; 3. 时钟配置总结&#xff1a;3.1 时钟树概要&#xff1a;3.2 IMX6ULL时钟概要及时钟树&#xff1a;3.3 IMX6ULL时钟配…

机器学习周记(第三十七周:语义分割)2024.4.29~2024.5.5

目录 摘要 ABSTRACT 1 DeepLabV3 1.1 空间金字塔池化&#xff08;ASPP&#xff09; 1.2 解码器&#xff08;Decoder&#xff09; 1.3 Xception 2 相关代码 摘要 DeepLabV3 是由Google Brain团队开发的深度学习模型&#xff0c;专注于语义分割任务。它采用深度卷积神经网…

QtWindows任务栏

目录 引言任务栏进度右键菜单缩略图工具栏完整代码 引言 针对Windows系统的任务栏&#xff0c;Qt基于系统的原生接口封装有一些非常见类&#xff0c;如QWinTaskbarButton、QWinTaskbarButton、QWinThumbnailToolBar等&#xff0c;用于利用工具栏提供更多的信息&#xff0c;诸如…

【CTF Web】XCTF GFSJ0482 weak_auth Writeup(弱口令+密码爆破)

weak_auth 小宁写了一个登陆验证页面&#xff0c;随手就设了一个密码。 解法 随便输入一些字符&#xff0c;提示以 admin 登录。 使用 Burp 抓包。 导入密码字典。 进行爆破。 得到密码。 账号&#xff1a;admin 密码&#xff1a;123456取得 flag。 Flag cyberpeace{42c9664…

Servlet框架

简介 Servlet是运行在web服务器或应用服务器上的程序&#xff0c;他是作为来自web浏览器或其他http客户端的请求和HTTP服务器上的数据库或应用程序之间的中间层。 使用Servlet可以手机来自网页表单的用户输入&#xff0c;呈现来自数据库或者其他源记录&#xff0c;还可以动态创…

解决网络ping不通问题

网络ping不通可能有多种原因&#xff0c;以下是一些常见的解决方法&#xff1a; 1. 检查IP地址和域名&#xff1a;确保你使用的是正确的IP地址或者域名来ping目标设备。如果IP地址或者域名错误&#xff0c;ping请求将无法到达目标设备。 2. 检查网络连接&#xff1a;首先确保…

【LeetCode刷题】153. 寻找旋转排序数组中的最小值

1. 题目链接2. 题目描述3. 解题方法4. 代码 1. 题目链接 153. 寻找旋转排序数组中的最小值 2. 题目描述 3. 解题方法 根据题目分析&#xff0c;可以明确一点&#xff0c;无论该数组如何旋转&#xff0c;都会有这样的一个性质&#xff0c;就是nums[0] > nums[n-1]&#xf…

RK3568 学习笔记 : u-boot 千兆网络无法 ping 通PC问题的解决方法二

参考 RK3568 学习笔记 : u-boot 千兆网络无法 ping 通PC问题的解决 前言 rk3568 rockchip 提供的 u-boot&#xff0c;默认的设备树需要读取 单独分区 resouce.img 镜像中的 设备树文件&#xff0c;也就是 Linux 内核的设备树 dtb 文件&#xff0c;gmac 网络才能正常的 ping 通…

STM32F1之FLASH闪存

目录 1. 简介 2. 闪存模块组织 3. FLASH基本结构 4. FLASH解锁 5. 使用指针访问存储器 6. 程序存储器全擦除 7. 程序存储器页擦除 8. 程序存储器编程 9. 选项字节 1. 简介 STM32F1系列的FLASH包含程序存储器、系统存储器和选项字节三个部分&#xff0c;通过…

【Android】Android应用性能优化总结

AndroidApp应用性能优化总结 最近大半年的时间里&#xff0c;大部分投在了某国内新能源汽车的某款AndroidApp开发上。 由于该App是该款车上&#xff0c;常用重点应用。所以车厂对应用性能的要求比较高。 主要包括&#xff1a; 应用冷启动达到***ms。应用热(温)启动达到***ms应…

RK3568笔记二十四:基于Flask的网页监控系统

若该文为原创文章&#xff0c;转载请注明原文出处。 此实验参考 《鲁班猫监控检测》&#xff0c;原代码有点BUG&#xff0c;已经下载不了。2. 鲁班猫监控检测 — [野火]嵌入式AI应用开发实战指南—基于LubanCat-RK系列板卡 文档 (embedfire.com) 一、简介 记录简单的摄像头监…

易语言IDE界面美化支持库

易语言IDE界面美化支持库 下载下来可以看到&#xff0c;是一个压缩包。 那么&#xff0c;怎么安装到易语言中呢&#xff1f; 解压之后&#xff0c;得到这两个文件。 直接将clr和lib丢到易语言安装目录中&#xff0c;这样子就安装完成了。 打开易语言&#xff0c;在支持库配置…

在营销的世界,你一定要记住:营满,则销

营销的世界中,有一个非常重要的一件事,这几个字一定要记住: 营满,则销;营未满,则不销。 你有没有把握,这是一个没办法可以复杂的东西,真得看营销人的直觉,营跟销是独立的两件事,营在营势,销是自然而然的。这里, 什么样的客户,看到什么样的产品。会有什么样的抗…

HCIP的学习(11)

OSPF的LSA详解 LSA头部信息 ​ [r2]display ospf lsdb router 1.1.1.1----查看OSPF某一条LSA的详细信息&#xff0c;类型以及LS ID参数。 链路状态老化时间 指一条LSA的老化时间&#xff0c;即存在了多长时间。当一条LSA被始发路由器产生时&#xff0c;该参数值被设定为0之后…

32 OpenCV Harris角点检测

文章目录 cornerHarris 算子示例 角点检测 cornerHarris 算子 void cv::cornerHarris ( InputArray src,OutputArray dst,int blockSize,int ksize,double K,int borderType BORDER_DEFAULT) src:待检测Harris角点的输入图像&#xff0c;图像必须是CV 8U或者CV 32F的单通道…