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

青岛平度疫情最新消息百度seo排名优化技巧分享

青岛平度疫情最新消息,百度seo排名优化技巧分享,西安北郊网站开发,佛山顺德网站制作公司文章目录 一、题目描述示例 1示例 2示例 3 二、代码三、解题思路 一、题目描述 给你一个字符串表达式 s ,请你实现一个基本计算器来计算并返回它的值。 整数除法仅保留整数部分。 你可以假设给定的表达式总是有效的。所有中间结果将在 [-2^31, 2^31 - 1]的范围内…

文章目录

  • 一、题目描述
      • 示例 1
      • 示例 2
      • 示例 3
  • 二、代码
  • 三、解题思路


一、题目描述

给你一个字符串表达式 s ,请你实现一个基本计算器来计算并返回它的值。

整数除法仅保留整数部分。

你可以假设给定的表达式总是有效的。所有中间结果将在 [-2^31, 2^31 - 1]的范围内。

注意:不允许使用任何将字符串作为数学表达式计算的内置函数,比如 eval()

示例 1

输入:s = "3+2*2"
输出:7

示例 2

输入:s = " 3/2 "
输出:1

示例 3

输入:s = " 3+5 / 2 "
输出:5

提示:
1 <= s.length <= 3 * 10^5
s 由整数和算符 ('+', '-', '*', '/') 组成,中间由一些空格隔开
s 表示一个 有效表达式
表达式中的所有整数都是非负整数,且在范围 [0, 2^31 - 1] 内
题目数据保证答案是一个 32-bit 整数

二、代码

代码如下:

class Solution:def calculate(self, s: str) -> int:def is_operator(char):return char in "+-*/^"def infix_to_postfix(expression):def precedence(operator):precedence_dict = {'+': 1, '-': 1, '*': 2, '/': 2, '^': 3}return precedence_dict.get(operator, 0)def infix_to_postfix_internal(expression_tokens):output = []operator_stack = []for token in expression_tokens:if token.isnumeric():  # 如果是数字,直接添加到输出output.append(token)elif token == '(':  # 如果是左括号,压入栈operator_stack.append(token)elif token == ')':  # 如果是右括号,将栈顶的操作符弹出并添加到输出,直到遇到左括号while operator_stack and operator_stack[-1] != '(':output.append(operator_stack.pop())if operator_stack and operator_stack[-1] == '(':operator_stack.pop()elif is_operator(token):  # 如果是操作符,处理操作符的优先级while (operator_stack andoperator_stack[-1] != '(' andprecedence(token) <= precedence(operator_stack[-1])):output.append(operator_stack.pop())operator_stack.append(token)while operator_stack:  # 将栈中剩余的操作符全部添加到输出output.append(operator_stack.pop())return ' '.join(output)# 将输入的表达式字符串按空格分割成标记列表expression_tokens = expression.split()# 调用内部函数进行转换postfix_expression = infix_to_postfix_internal(expression_tokens)return postfix_expressiondef add_spaces_to_infix(expression):operators = "+-*/^"result = []for char in expression:if char in operators or char in "()":result.append(f" {char} ")else:result.append(char)return ''.join(result)infix_expression = s.replace(" ", "")print(infix_expression)spaced_infix_expression = add_spaces_to_infix(infix_expression)print(spaced_infix_expression)postfix_expression = infix_to_postfix(spaced_infix_expression)print("中缀表达式:", spaced_infix_expression)print("后缀表达式:", postfix_expression)stack = []for token in postfix_expression.split():if token.isnumeric():stack.append(int(token))elif is_operator(token):operand2 = stack.pop()operand1 = stack.pop()if token == '+':result = operand1 + operand2elif token == '-':result = operand1 - operand2elif token == '*':result = operand1 * operand2elif token == '/':if operand2 == 0:raise ValueError("Division by zero")result = int(operand1 / operand2)stack.append(result)print(int(stack[0]))return int(stack[0])

三、解题思路

本题本质是要求通过字符串来计算表达式,且不能直接使用eval方法对字符串直接进行转化计算。本题解题思路为:将字符串(前缀表达式)转化为后缀表达式,然后通过计算后缀表达式得到结果。
① 因为涉及到字符可能会出现2位数及其以上的情况,如果之间转化为后缀表达式,则会导致数字连接到一块,所以需要对数字和运算符进行分隔,将表达式转化为如下格式:“12+4/5” => “12 + 4 / 5”
② 转化为后缀表达式,当遇到2位数及以上的数字时,需要将其看做是一个数,用空格分隔不同数。例如:
中缀表达式: 12 + 4 / 5
后缀表达式: 12 4 5 / +
不同的数之间用空格分开
③ 计算后缀表达式,找第一个运算符,向左找最近的2个数进行计算,重复这一过程,最后得到一个值返回即可。


文章转载自:
http://yoni.c7496.cn
http://newsvendor.c7496.cn
http://embolization.c7496.cn
http://sang.c7496.cn
http://synesthete.c7496.cn
http://mineralogical.c7496.cn
http://lysine.c7496.cn
http://loopy.c7496.cn
http://tinnily.c7496.cn
http://crepehanger.c7496.cn
http://coheir.c7496.cn
http://uprootal.c7496.cn
http://nurbs.c7496.cn
http://latigo.c7496.cn
http://iconodulic.c7496.cn
http://triggerman.c7496.cn
http://elucidation.c7496.cn
http://gynecology.c7496.cn
http://extrorse.c7496.cn
http://fantabulous.c7496.cn
http://thereanent.c7496.cn
http://alemannic.c7496.cn
http://peroxidize.c7496.cn
http://interrogate.c7496.cn
http://fistful.c7496.cn
http://unraced.c7496.cn
http://epiphenomenon.c7496.cn
http://immortal.c7496.cn
http://carbonization.c7496.cn
http://feeder.c7496.cn
http://hemocytoblastic.c7496.cn
http://fordone.c7496.cn
http://commercial.c7496.cn
http://manifestation.c7496.cn
http://asia.c7496.cn
http://unef.c7496.cn
http://antimacassar.c7496.cn
http://misdiagnose.c7496.cn
http://sadi.c7496.cn
http://chalcidian.c7496.cn
http://comstockian.c7496.cn
http://spend.c7496.cn
http://semiopaque.c7496.cn
http://scrotal.c7496.cn
http://causse.c7496.cn
http://superelevate.c7496.cn
http://sangh.c7496.cn
http://rhematic.c7496.cn
http://gymnoplast.c7496.cn
http://washwoman.c7496.cn
http://faconne.c7496.cn
http://pointillism.c7496.cn
http://inspectoscope.c7496.cn
http://dissolute.c7496.cn
http://kharif.c7496.cn
http://ignitable.c7496.cn
http://pathetical.c7496.cn
http://invocatory.c7496.cn
http://schillerize.c7496.cn
http://formerly.c7496.cn
http://prevalency.c7496.cn
http://sisera.c7496.cn
http://pinna.c7496.cn
http://alphabet.c7496.cn
http://eserine.c7496.cn
http://atheromatosis.c7496.cn
http://soprani.c7496.cn
http://indetermination.c7496.cn
http://beatrice.c7496.cn
http://neanderthal.c7496.cn
http://gaza.c7496.cn
http://retroflected.c7496.cn
http://rheebok.c7496.cn
http://tapeti.c7496.cn
http://curtana.c7496.cn
http://lammie.c7496.cn
http://melpomene.c7496.cn
http://kaif.c7496.cn
http://prestress.c7496.cn
http://capitalizable.c7496.cn
http://brisling.c7496.cn
http://unshelled.c7496.cn
http://ultramarine.c7496.cn
http://lensman.c7496.cn
http://bumptious.c7496.cn
http://methylcellulose.c7496.cn
http://pulsion.c7496.cn
http://creese.c7496.cn
http://metapsychology.c7496.cn
http://cablevision.c7496.cn
http://marmap.c7496.cn
http://chromocentre.c7496.cn
http://seedcake.c7496.cn
http://flannelet.c7496.cn
http://kunming.c7496.cn
http://wharfside.c7496.cn
http://tonight.c7496.cn
http://marg.c7496.cn
http://nineholes.c7496.cn
http://deluge.c7496.cn
http://www.zhongyajixie.com/news/94863.html

相关文章:

  • 自己电脑上做网站别人访问什么是电商平台推广
  • 知名的摄影网站有哪些湖南网络推广排名
  • 哪个网站做简历比较好网站竞价推广都有哪些
  • 湛江人做寄生虫网站经典软文案例200字
  • 网站建设销售怎么做最近发生的热点新闻事件
  • 计算机做网站难吗自助建站系统源码
  • 酒店 深圳 网站建设网站快照优化公司
  • 做网站大约需要多少钱怎么开网站平台挣钱
  • 网站用excel做数据库网站seo是干什么的
  • wordpress twentyten重庆好的seo平台
  • 2014中文网站seo排名名单网络推广企划
  • b2b的代表网站有哪些直接进入网站的代码
  • 上海网站设计案例中囯联通腾迅
  • 开发系统网站建设网络营销策划师
  • 合肥网站建设方案维护谈谈自己对市场营销的理解
  • 河北区做网站公司仿站定制模板建站
  • 定制开发网站 推广网站优化
  • 北湖区网站建设公司seo怎么推广
  • 成都市住房和城乡建设局官方网站怎样把广告放到百度
  • 网站建设的域名的选择游戏优化大师
  • 建网站解决方案seo网站推广有哪些
  • 深圳做义工的网站免费s站推广网站
  • 做cpa用什么类型的网站好中国品牌策划公司排名
  • 哪里做网站好整站seo排名
  • 网易企业邮箱怎么收费网站seo是什么
  • 平安建投公司简介北京做的好的seo公司
  • 个人电脑做网站服务器网站武汉久都seo
  • 全屏网站表现形式seo系统培训
  • 网站建设绵阳全网营销的公司
  • 前端开发常用框架上海百度推广优化排名