| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> 【力扣每日一题】——向表达式添加括号后的最小结果 -> 正文阅读 |
|
[数据结构与算法]【力扣每日一题】——向表达式添加括号后的最小结果 |
力扣每日一题系列简介: 有些题看起来不难却很复杂,但是如果巧妙的应用Java中的内置函数解决起来就变得简单很多,这些题没见过是真的难想到用什么内置函数,而且就算见过也很容易遗忘,【力扣每日一题】系列将总结归纳诸如使用巧妙方法解决的题、经典算法模板题、高频面试题等力扣算法题 🍋1.题目描述:
这是第288场力扣周赛第二题 原题链接 简单来说就是给定一个字符串,这个字符串是两数之和的数学表达式,然后在"+"号左右分别添加左右括号,组成一个新的数学表达式,求可能组成的所有数学表达式的最小值所对应的数学表达式 🍊2.题目分析这道题刚开始看的时候感觉文字描述很多,看完理解意思其实思路并不难,而且给定字符串的长度范围为[3,10]并且是合法的数学表达式,直接暴力循环模拟每一种情况就好了(但是需要注意的细节很多😭😭😭) 周赛时我的思路是: 1. 先将字符串以“+”为分隔符分成两个字符串s1、s2 2. 然后使用StringBuffer进行拼接,循环每一个左括号和右括号的位置 3. 使用一个函数来计算每次模拟的数学表达式的值,最后记录最小值的表达式 思路很清晰,但是具体实现的时候写了一百多行的代码,问题一堆,跑都跑不起来😣😣😣 遇到的问题: 1. split()如果使用"+“需要转义字符 “\”,而转义字符”\“也需要转义字符”\“,在网上查阅了一下split()函数是支持正则表达式的因此对于 | , + , * , ^ , $ , / , | , [ , ] , ( , ) , . , \ 等字符使用split()函数需要写成”\\+字符",例如本题应是**“\\+”** 2. StringBuffer进行拼接时两层for循环,需要两个StringBuffer对象不然就会出现一堆奇怪的数学表达式😭😭😭 3. 忘记了Integer.parseInt()可以将字符串类型的数字转化为整数类型的数字 4. 由于大早上被抓去做核酸,写周赛时又困又饿,导致循环遍历搞混淆了一直运行超时,果然对于我这种菜汪状态再不好简直就是要命😵😵😵 🌰3.代码实现
此代码实现的优势: 1. 以’+'下标为界限,前后两部分的字符串以substring()子字符串函数模拟,分成三个部分对应 括号左右字符串 和括号内字符串 比我在那字符串拼接简化很多倍😂😂😂 2. 使用Integer.parseInt()进行类型转换,大大简化了计算 3. 使用format字符串格式化函数添加括号,简直妙不可言!!!(这个函数我只在python中经常用到,在Java中都忘了还有这个函数,又吃了没文化的亏😂😂😂) |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/26 10:28:53- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |