leetcode中如何为运算表达式设计优先级
发表于:2025-02-07 作者:千家信息网编辑
千家信息网最后更新 2025年02月07日,这篇文章主要为大家展示了"leetcode中如何为运算表达式设计优先级",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"leetcode中如何为运算表达式设计
千家信息网最后更新 2025年02月07日leetcode中如何为运算表达式设计优先级
这篇文章主要为大家展示了"leetcode中如何为运算表达式设计优先级",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"leetcode中如何为运算表达式设计优先级"这篇文章吧。
给定一个含有数字和运算符的字符串,为表达式添加括号,改变其运算优先级以求出不同的结果。你需要给出所有可能的组合的结果。有效的运算符号包含 +, - 以及 * 。
示例 1:
输入: "2-1-1"
输出: [0, 2]
解释:
((2-1)-1) = 0
(2-(1-1)) = 2
示例 2:
输入: "2*3-4*5"
输出: [-34, -14, -10, -10, 10]
解释:
(2*(3-(4*5))) = -34
((2*3)-(4*5)) = -14
((2*(3-4))*5) = -10
(2*((3-4)*5)) = -10
(((2*3)-4)*5) = 10
解题思路:
1,将输入字符串拆分成token
2,在任意运算符所在位置将数组拆分成两部分
3,递归对两部分求值
4,对值进行运算
func diffWaysToCompute(input string) []int {
t:=strToTok(input)
fmt.Println(t)
return cal(t)
}
func cal(t[]Token)[]int{
var r []int
if len(t)==1{
r=append(r,t[0].value)
return r
}
for i:=1;i
la:=cal(t[:i])
ra:=cal(t[i+1:])
for _,l:=range la{
for _,r1:=range ra{
switch t[i].op{
case '+':
r=append(r,l+r1)
case '-':
r=append(r,l-r1)
case '*':
r=append(r,l*r1)
}
}
}
}
return r
}
type Token struct{
tokenType int //0 num 1 op
value int
op byte
}
func strToTok(input string)[]Token{
var r []Token
for i:=0;i
if input[i]=='+' || input[i]=='-' || input[i]=='*' {
r=append(r,Token{
tokenType:1,
op:input[i],
})
i++
}
num:=0
for i
='0' && input[i]<='9'{ num=num*10+int(input[i]-'0')
i++
}
r=append(r,Token{
value:num,
})
}
return r
}
以上是"leetcode中如何为运算表达式设计优先级"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
运算
优先级
表达式
设计
内容
篇文章
输入
字符
字符串
示例
结果
运算符
部分
学习
帮助
解释
输出
不同
有效
位置
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
倩女幽魂挣钱软件开发
什么是监控的中心管理服务器
抖音小店软件开发选哪个行业
我的世界ec服务器好玩么
数据库ott软件
科技与互联网的好处
冒险岛2武器数据库
去红眼软件开发
河南计算机网络技术专升本上岸
软件开发专业需要什么学科
杞县租房软件开发
网络安全贷款有什么
宜昌软件开发工程师证
服务器直配一颗cpu
云服务器到期网站还能上
贵广网络安全生产法
网络安全协议基础知识
医药魔方数据库可以试用吗
滨州财务软件开发咨询
tcC语言软件开发工具
教务系统的数据库设计
数据库作业的用法
成都慧泽嘉诚网络技术有限公司
英文数据库怎么转主题词
w7服务器管理在哪里
办公软件开发公司找哪家
服务器安全 安骑士
服务器忍法神威雷切
服务器磁盘有没有阵列有啥区别
数据库返回的宏代码