LeetCode 题解(211) : Expression Add Operators

2024-05-28 08:58

本文主要是介绍LeetCode 题解(211) : Expression Add Operators,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目:

Given a string that contains only digits 0-9 and a target value, return all possibilities to add binary operators (not unary) +, -, or * between the digits so they evaluate to the target value.

Examples:

"123", 6 -> ["1+2+3", "1*2*3"] 
"232", 8 -> ["2*3+2", "2+3*2"]
"105", 5 -> ["1*0+5","10-5"]
"00", 0 -> ["0+0", "0-0", "0*0"]
"3456237490", 9191 -> []
题解:

注意的问题:

1. 有可能string很长,所以要用长整数。

2.需要记录last oprand,为的是处理乘号的情况。乘号时的计算公式为: result - lastOP + lastOP * curVaule,如 2 + 3 * 5, 当计算到要乘5时,result = 2 + 3 = 5, lastOp = 3, curValue = 5, 则最终结果为: 5 - 3 + 3 * 5 = 17 = 2 + 3 * 5。

3. 记录当前结果,用于在num长度为零时, 判断是否与target相等,并加入最终的results中。

4. 需要跳过长于一个零的操作数,如“00”, “000”, etc.

5. 按左操作数从长度为1 到长度为len(num)循环, 并递归。

C++版:

class Solution {
public:vector<string> addOperators(string num, int target) {vector<string> results;opRecur(num, target, 0, 0, "", results);return results;}void opRecur(string num, int target, long long lastOp, long long result, string expression, vector<string> & results) {if(num.length() == 0 && result == target) {results.push_back(expression);return;}for(int i = 1; i <= num.length(); i++) {string cur = num.substr(0, i);string rest = num.substr(i);long long curV = stoll(cur);if(cur.length() > 1 && cur[0] == '0')continue;if(expression.length() == 0) {opRecur(rest, target, curV, curV, cur, results);} else {opRecur(rest, target, curV, result + curV, expression + "+" + cur, results);opRecur(rest, target, -curV, result - curV, expression + "-" + cur, results);opRecur(rest, target, lastOp * curV, result - lastOp + lastOp * curV, expression + "*" + cur, results);}}}
};

Java版:

public class Solution {public List<String> addOperators(String num, int target) {List<String> results = new ArrayList<>();opRecur(num, target, 0, 0, "", results);return results;}private void opRecur(String num, int target, long lastOp, long result, String expression, List<String> results) {if(num.length() == 0) {if(target == result)results.add(expression);return;} for(int i = 1; i <= num.length(); i++) {String cur = num.substring(0, i);if(cur.length() > 1 && cur.charAt(0) == '0')continue;String rest = num.substring(i);long curV = Long.parseLong(cur);if(expression.length() == 0) {opRecur(rest, target, curV, curV, expression + cur, results);} else {opRecur(rest, target, curV, result + curV, expression + "+" + cur, results);opRecur(rest, target, -curV, result - curV, expression + "-" + cur, results);opRecur(rest, target, curV * lastOp, result - lastOp + lastOp * curV, expression + "*" + cur, results);}}}
}

Python版:

class Solution(object):def addOperators(self, num, target):""":type num: str:type target: int:rtype: List[str]"""results = []self.opRecur(num, target, 0, 0, "", results)return resultsdef opRecur(self, num, target, lastOp, result, expression, results):if len(num) == 0:if target == result:results.append(expression)returnfor i in range(1, len(num) + 1):cur = num[:i]if len(cur) > 1 and cur[0] == "0":continuerest = num[i:]curV = int(cur)if len(expression) == 0:self.opRecur(rest, target, curV, curV, expression + cur, results)else:self.opRecur(rest, target, curV, result + curV, expression + "+" + cur, results)self.opRecur(rest, target, -curV, result - curV, expression + "-" + cur, results)self.opRecur(rest, target, lastOp * curV, result - lastOp + lastOp * curV, expression + "*" + cur, results)

这篇关于LeetCode 题解(211) : Expression Add Operators的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1010112

相关文章

LeetCode11. 盛最多水的容器题解

LeetCode11. 盛最多水的容器题解 题目链接: https://leetcode.cn/problems/container-with-most-water 示例 思路 暴力解法 定住一个柱子不动,然后用其他柱子与其围住面积,取最大值。 代码如下: public int maxArea1(int[] height) {int n = height.length;int

LeetCode--231 2的幂

题目 给定一个整数,编写一个函数来判断它是否是 2 的幂次方。 示例 示例 1:输入: 1输出: true解释: 20 = 1示例 2:输入: 16输出: true解释: 24 = 16示例 3:输入: 218输出: false class Solution {public:bool isPowerOfTwo(int n) {if (n <= 0) return fals

LeetCode--234 回文链表

题目 请判断一个链表是否为回文链表。 示例 示例 1:输入: 1->2输出: false示例 2:输入: 1->2->2->1输出: true /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode(int x) : val

LeetCode--220 存在重复元素 III

题目 给定一个整数数组,判断数组中是否有两个不同的索引 i 和 j,使得 nums [i] 和 nums [j] 的差的绝对值最大为 t,并且 i 和 j 之间的差的绝对值最大为 ķ。 示例 示例 1:输入: nums = [1,2,3,1], k = 3, t = 0输出: true示例 2:输入: nums = [1,0,1,1], k = 1, t = 2输出: true示例

LeetCode--217 存在重复元素

题目 给定一个整数数组,判断是否存在重复元素。如果任何值在数组中出现至少两次,函数返回 true。如果数组中每个元素都不相同,则返回 false。 示例 示例 1:输入: [1,2,3,1]输出: true示例 2:输入: [1,2,3,4]输出: false示例 3:输入: [1,1,1,3,3,4,3,2,4,2]输出: true class Solution {p

LeetCode--214 最短回文串

题目 给定一个字符串 s,你可以通过在字符串前面添加字符将其转换为回文串。找到并返回可以用这种方式转换的最短回文串。 示例 示例 1:输入: "aacecaaa"输出: "aaacecaaa"示例 2:输入: "abcd"输出: "dcbabcd" 思路: 我们需要添加多少个字符与给定字符串的前缀子串回文的长度有关. 也就是说去掉其前缀的回文子串,我们只需要补充剩下的子串的逆序

LeetCode--206 反转链表

题目 反转一个单链表。 示例 示例:输入: 1->2->3->4->5->NULL输出: 5->4->3->2->1->NULL class Solution {public:ListNode* reverseList(ListNode* head) {if (head == nullptr || head->next == nullptr){return head;}ListNo

LeetCode--204 计数质数

题目 统计所有小于非负整数 n 的质数的数量。 示例 示例:输入: 10输出: 4解释: 小于 10 的质数一共有 4 个, 它们是 2, 3, 5, 7 。 class Solution {public:int countPrimes(int n) {if (n <= 2) return 0;int cnt = 0;vector<bool> isPrime(n, true);

LeetCode--198 打家劫舍

题目 你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。给定一个代表每个房屋存放金额的非负整数数组,计算你在不触动警报装置的情况下,能够偷窃到的最高金额。 示例 示例 1:输入: [1,2,3,1]输出: 4解释: 偷窃 1 号房屋 (金额 =

LeetCode--171 Excel表列序号

题目 给定一个Excel表格中的列名称,返回其相应的列序号。例如,A -> 1B -> 2C -> 3...Z -> 26AA -> 27AB -> 28 ... 示例 示例 1:输入: "A"输出: 1示例 2:输入: "AB"输出: 28示例 3:输入: "ZY"输出: 701 class Solution {public:int titleToNumber(strin