华为od机试真题:火星符号运算(Python)

题目描述

已知火星人使用的运算符号为 #$

其与地球人的等价公式如下

复制代码
x#y=2*x+3*y+4
x$y=3*x+y+2
  1. x y是无符号整数。
  2. 地球人公式按照c语言规则进行计算。
  3. 火星人公式中,# 号的优先级高于 $ ,相同的运算符,按从左往右的顺序计算

现有一段火星人的字符串报文,请你来翻译并计算结果

输入描述

火星人的字符串表达式(结尾不带回车换行)

输入的字符串说明:字符串为仅无符号整数和操作符(#、)组成的计算表达式,例如:123#45#67$78

  1. 用例保证字符串中,操作数与操作符之间没有任何分隔符

  2. 用例保证操作数取值范围为 3232 为无符号整数

  3. 保证输入以及计算结果不会出现int整数溢出

  4. 保证输入的字符串为合法的求值报文,例如:123#45#6778

  5. 保证不会出现非法的求值报文,例如类似这样字符串:

    复制代码
    #4$5 //缺少操作数
    4$5# //缺少操作数
    4#$5 //缺少操作数
    4 $5 //有空格
    3+4-5*6/7 //有其他操作符
    1234567897654321$54321 //32位整数计算溢出

输出描述

根据输入的火星人字符串输出计算结果(结尾不带回车换行)

示例1

复制代码
输入:
7#6$5#12

输出:
157

说明:
7#6$5#12
=(4*7+3*6+2)$5#12
=48$5#12
=48$(4*5+3*12+2)
=48$58
=2*48+58+3
=157

题解

解题思路:

  1. 题目要求对火星人的字符串表达式进行翻译并计算结果,其中火星人的运算符为 #$,并给出了等价的地球人公式。
  2. 使用栈来模拟计算过程,遍历字符串,遇到数字则累积,遇到运算符则进行相应的计算。
  3. 定义优先级,按照规定的优先级顺序进行计算。
  4. 最终栈中的结果即为计算结果。

代码大致描述:

  1. 使用栈 nums 存储数字,栈 ops 存储运算符,变量 t 用于临时存储数字。
  2. 定义操作符的优先级 priority
  3. 定义一个计算的函数 calc,用于出栈计算,并根据运算符进行相应的计算。
  4. 遍历字符串,遇到数字则累积到 t 中,遇到运算符则将 t 压入 nums,并根据优先级进行出栈计算。
  5. 遍历结束后,将 t 压入 nums
  6. 最后,根据运算符的优先级,进行出栈计算直到操作符栈为空,返回栈顶元素作为最终结果。

Python

python 复制代码
def solve(s: str) -> int:
    # 数据栈, 操作符栈, 数字临时变量
    nums, ops, t = [], [], 0
    # 操作符优先级
    priority = {'#': 2, '$': 1}

    def calc():  # 进行出栈计算
        y, x = nums.pop(), nums.pop()
        op = ops.pop()
        if op == '#':
            nums.append(4 * x + 3 * y + 2)
        else:
            nums.append(2 * x + y + 3)

    for c in s:
        if c.isdigit():
            t = t * 10 + int(c)
            continue

        nums.append(t)

        # 相同优先级或之前优先级高则出栈计算
        while ops and priority[ops[-1]] >= priority[c]:
            calc()

        ops.append(c)
        t = 0
    nums.append(t)

    # 出栈计算, 直到操作符栈为空
    while ops:
        calc()

    return nums[-1]


print(solve(input()))

相关练习题

题号 题目 难易
LeetCode 227 227. 基本计算器 II 中等
LeetCode 224 224. 基本计算器 困难

2024华为OD机试(C卷+D卷)最新题库【超值优惠】Java/Python/C++合集

【限时返现】可联系作者返¥20 💰

🙏整理题解不易, 如果有帮助到您,请给点个赞 ‍❤️‍ 和收藏 ⭐,让更多的人看到。🙏🙏🙏

相关推荐
Learn Beyond Limits8 分钟前
Transfer Learning|迁移学习
人工智能·python·深度学习·神经网络·机器学习·ai·吴恩达
梁辰兴1 小时前
数据结构:排序
数据结构·算法·排序算法·c·插入排序·排序·交换排序
野犬寒鸦1 小时前
力扣hot100:搜索二维矩阵 II(常见误区与高效解法详解)(240)
java·数据结构·算法·leetcode·面试
菜鸟得菜1 小时前
leecode kadane算法 解决数组中子数组的最大和,以及环形数组连续子数组的最大和问题
数据结构·算法·leetcode
love530love2 小时前
【保姆级教程】阿里 Wan2.1-T2V-14B 模型本地部署全流程:从环境配置到视频生成(附避坑指南)
人工智能·windows·python·开源·大模型·github·音视频
楼田莉子2 小时前
C++算法专题学习——分治
数据结构·c++·学习·算法·leetcode·排序算法
He1955012 小时前
Go初级之十:错误处理与程序健壮性
开发语言·python·golang
一支鱼2 小时前
leetcode常用解题方案总结
前端·算法·leetcode
ulias2123 小时前
各种背包问题简述
数据结构·c++·算法·动态规划
m0_570466413 小时前
代码随想录算法训练营第二十八天 | 买卖股票的最佳实际、跳跃游戏、K次取反后最大化的数组和
java·开发语言·算法