首页 > 编程语言 >C++算法:给表达式添加运算符

C++算法:给表达式添加运算符

时间:2023-10-24 16:02:56浏览次数:40  
标签:std const long 运算符 num C++ iBit 表达式 it1


题目

给定一个仅包含数字 0-9 的字符串 num 和一个目标值整数 target ,在 num 的数字之间添加 二元 运算符(不是一元)+、- 或 * ,返回 所有 能够得到 target 的表达式。
注意,返回表达式中的操作数 不应该 包含前导零。
示例 1:
输入: num = “123”, target = 6
输出: [“1+2+3”, “123”]
解释: “123” 和 “1+2+3” 的值都是6。
示例 2:
输入: num = “232”, target = 8
输出: [“23+2", "2+32”]
解释: “23+2” 和 “2+32” 的值都是8。
示例 3:
输入: num = “3456237490”, target = 9191
输出: []
解释: 表达式 “3456237490” 无法得到 9191 。

2023年5月版

class Solution {
 public:
 vector addOperators(string num, int target) {
 std::unordered_map < string, std::tuple< long long, long long, long long >> preValueMulValue;
 preValueMulValue.emplace(std::string(“”) + num[0], std::make_tuple(num[0] - ‘0’, num[0] - ‘0’, num[0] - ‘0’));
 for (int i = 1; i < num.size(); i++)
 {
 const char& ch = num[i];
 const int iBit = num[i] - ‘0’;
 std::unordered_map < string, std::tuple< long long, long long, long long >> valueMulValue;
 for (const auto& it1 : preValueMulValue)
 {
 const long long& iValue = std::get<0>(it1.second);
 const long long& iMul = std::get<1>(it1.second);
 const long long& iEnd = std::get<2>(it1.second);
 const long long iMulPre = (0 == iEnd) ? 0 : iMul / iEnd;
 //不加符号
 if ((0 != iEnd) )
 {
 valueMulValue.emplace(it1.first + ch, std::make_tuple(iValue + iMulPre * (iEnd * 9 + iBit), iMulPre * (iEnd * 10 + iBit), iEnd * 10 + iBit));
 }
 //增加加号
 valueMulValue.emplace(it1.first + ‘+’ + ch, std::make_tuple(iValue + iBit,iBit,iBit));
 //增加减号
 valueMulValue.emplace(it1.first + ‘-’ + ch, std::make_tuple(iValue - iBit, -iBit, iBit));
 //增加乘号
 valueMulValue.emplace(it1.first + '’ + ch, std::make_tuple(iValue + iMul(iBit - 1), iMul*iBit,iBit));
 }
 preValueMulValue.swap(valueMulValue);
 }
 vector vRet;
 for (const auto& it1 : preValueMulValue)
 {
 if (target == std::get<0>( it1.second))
 {
 vRet.emplace_back(it1.first);
 }
 }
 return vRet;
 }};

2023年8月

class Solution {
 public:
 vector addOperators(string num, int target) {
 m_strNum = num;
 m_iTarget = target;
 const auto& iBit = num.front() - ‘0’;
 dfs(num.substr(0, 1),1, iBit, iBit, iBit);
 return m_vRet;
 }
 void dfs(string exp, int hasDo,const long long llValue, long long endMulValue,long long endValue)
 {
 if (hasDo == m_strNum.length())
 {
 if (llValue == m_iTarget)
 {
 m_vRet.emplace_back(exp);
 }
 return ;
 }
 const auto& chBit = m_strNum[hasDo] ;
 const auto& iBit = chBit - ‘0’;
 //1+23 llValue=7 endMulValue=6 endValue=3 exincludeEnd=1 preMul=2
 long long exincludeEnd = llValue - endMulValue;
 long long preMul = (0== endValue)? 0 : endMulValue / endValue; 
 #define NEW_END_MUL (preMulllNewEnd)
 //直接连接
 //1+234 llValue=69 endMulValue=68 endValue=34 exincludeEnd=1 preMul=2
 long long llNewEnd = endValue * 10 + ((endValue<0) ? -iBit : iBit);
 if (0 != endValue )
 {
 dfs(exp + chBit, hasDo + 1, exincludeEnd + NEW_END_MUL, NEW_END_MUL, llNewEnd);
 }
 //乘以
 llNewEnd = iBit;
 preMul = endMulValue;
 dfs(exp + ''+ chBit, hasDo + 1, exincludeEnd + NEW_END_MUL, NEW_END_MUL, llNewEnd);
 preMul = 1;
 exincludeEnd = llValue;
 dfs(exp + ‘+’ + chBit, hasDo + 1, exincludeEnd + NEW_END_MUL, NEW_END_MUL, llNewEnd);
 llNewEnd = -iBit;
 dfs(exp + ‘-’ + chBit, hasDo + 1, exincludeEnd + NEW_END_MUL, NEW_END_MUL, llNewEnd);
 }
 string m_strNum;
 int m_iTarget;
 vector m_vRet;
 };

扩展阅读


相关下载

想高屋建瓴的学习算法,请下载《闻缺陷则喜算法册》doc版

鄙人想对大家说的话

闻缺陷则喜是一个美好的愿望,早发现问题,早修改问题,给老板节约钱。

墨家名称的来源:有所得以墨记

之。 |
|如果程序是一条龙,那算法就是他的是睛|

测试环境

操作系统:win7 开发环境: VS2019 C++17
或者 操作系统:win10 开发环境: VS2022 C++17

C++算法:给表达式添加运算符_表达式


标签:std,const,long,运算符,num,C++,iBit,表达式,it1
From: https://blog.51cto.com/u_15724537/8005224

相关文章

  • C++数位算法:数字1的个数
    题目给定一个整数n,计算所有小于等于n的非负整数中数字1出现的个数。示例1:输入:n=13输出:6示例2:输入:n=0输出:0提示:0<=n<=1092023年1月版classSolution{public:intcountDigitOne(intn){intiNum=0;intiMul=1;for(inti=0;i<9;i++){......
  • C++桶排序算法的应用:存在重复元素 III
    题目给你一个整数数组nums和两个整数indexDiff和valueDiff。找出满足下述条件的下标对(i,j):i!=j,abs(i-j)<=indexDiffabs(nums[i]-nums[j])<=valueDiff如果存在,返回true;否则,返回false。示例1:输入:nums=[1,2,3,1],indexDiff=3,valueDiff=0输出......
  • C++前缀和算法应用:矩形区域不超过 K 的最大数值和
    题目给你一个mxn的矩阵matrix和一个整数k,找出并返回矩阵内部矩形区域的不超过k的最大数值和。题目数据保证总会存在一个数值和不超过k的矩形区域。示例1:输入:matrix=[[1,0,1],[0,-2,3]],k=2输出:2解释:蓝色边框圈出来的矩形区域[[0,1],[-2,3]]的数值和是......
  • 时间复杂度O(40n*n)的C++算法:修改图中的边权
    1.12.1.题目给你一个n个节点的无向带权连通图,节点编号为0到n-1,再给你一个整数数组edges,其中edges[i]=[ai,bi,wi]表示节点ai和bi之间有一条边权为wi的边。部分边的边权为-1(wi=-1),其他边的边权都为正数(wi>0)。你需要将所有边权为-1的边都修改为范......
  • GO语言中的运算符
    算法术运算符运算符描述+相加-相减*相乘/相除%求余,仅限整数//arithmetic算术运算funcarithmetic(){ varafloat32=8 varbfloat32=3 varcfloat32=a+b vardfloat32=a-b varefloat32=a*b varffloat32=a/b ......
  • 在C++中,互斥变量(std::mutex)是用于保护共享资源的重要工具,但它们确实有一些局限性,其中
    在C++中,互斥变量(std::mutex)是用于保护共享资源的重要工具,但它们确实有一些局限性,其中之一是无法保证包含指针的区域的多线程安全。这是因为互斥锁本质上只能保护它们所保护的代码块,而不会考虑指针指向的数据。下面是一些与互斥锁和指针相关的常见问题和注意事项:共享数据的复制:......
  • C++_Cmake的使用
    C++系统版本、软件依赖版本、组件LSB(全称:LinuxStandardsBase)LSBsharedobjectELF是ExecutableLinkableFormat的缩写,是Linux的链接、可执行、共享库的格式标准,COFF:CommonObjectCOFF(通用对象文件格式) 编译器:简单构建gcc编译流程分为4个步骤,分......
  • C++初识(续篇)
    1.2注释作用:在代码中加一些说明和解释,方便自己或其他程序员阅读代码两中格式单行注释:通常放在一行代码的上方,或者一条语句的末尾,对该行代码说明//这样的是单行注释多行注释:通常放在一段代码的上方,对该段代码做整体说明/*这种的是多行注释可以写好多行*/......
  • c++中的宏#define用途
    宏的一些作用,包括但不限于这些定义一个变量、字符串、类型定义一个函数、条件表达式条件编译、调试信息,异常类定义结构体、命名空间定义模版、枚举、函数对象#define宏定义在C++中用于定义常量、函数、条件编译、字符串、条件表达式、变量、注释、调试信息、类型、函数等,下面是一些......
  • C++的编译链接与在vs中build提速
    通过gcc或msvc,clang等编译器编译出来的C++源文件是.o文件。在windows上也就是PE文件,linux为ELF文件,在这一步中,调用其它代码文件中的函数的函数地址是未知的(00000),等到链接之后才会替换掉函数地址的linux,windows可执行文件(ELF、PE)C++是如何编译的C/C++编译过程主要分为4个过程......