JAVA学习-练习试用Java实现“给表达式添加运算符”

问题:

给定一个仅包含数字 0-9 的字符串 num 和一个目标值整数 target ,在 num 的数字之间添加 二元 运算符(不是一元)+、- 或 * ,返回所有能够得到目标值的表达式。

示例 1:

输入:

num =

"123", target = 6

输出: ["1+2+3", "1*2*3"]

示例 2:

输入:

num =

"232", target = 8

输出: ["2*3+2", "2+3*2"]

示例 3:

输入:

num =

"105", target = 5

输出: ["1*0+5","10-5"]

示例 4:

输入:

num =

"00", target = 0

输出: ["0+0", "0-0", "0*0"]

示例 5:

输入:

num =

"3456237490", target = 9191

输出: []

提示:

1 <= num.length <= 10

num 仅含数字

-231 <= target <= 231 - 1

解答思路:

以下是使用 Java 语言解决此问题的步骤:

  1. 定义一个函数来计算表达式的值。

  2. 使用回溯法来生成所有可能的表达式。

  3. 在回溯过程中,根据当前数字和运算符计算表达式的值,并与目标值进行比较。

  4. 如果表达式的值等于目标值,则将其添加到结果列表中。

  5. 最终返回结果列表。

以下是完整的 Java 代码:

java 复制代码
import java.util.ArrayList;
import java.util.List;

public class AddOperators {

    public static List<String> addOperators(String num, int target) {
        List<String> result = new ArrayList<>();
        backtrack(num, target, 0, 0, 0, "", result);
        return result;
    }

    public static void backtrack(String num, int target, int index, long prev, long curr, String expression, List<String> result) {
        if (index == num.length()) {
            if (curr == target) {
                result.add(expression);
            }
            return;
        }

        for (int i = index; i < num.length(); i++) {
            if (i!= index && num.charAt(index) == '0') {
                break;
            }

            long value = Long.parseLong(num.substring(index, i + 1));

            if (index == 0) {
                backtrack(num, target, i + 1, value, value, expression + value, result);
            } else {
                backtrack(num, target, i + 1, prev, curr + value, expression + "+" + value, result);
                backtrack(num, target, i + 1, -prev, curr - value, expression + "-" + value, result);
                backtrack(num, target, i + 1, prev * value, curr - prev + prev * value, expression + "*" + value, result);
            }
        }
    }

    public static void main(String[] args) {
        String num = "123";
        int target = 6;
        List<String> expressions = addOperators(num, target);
        for (String expression : expressions) {
            System.out.println(expression);
        }
    }
}

在上述代码中,'addOperators' 函数接受数字字符串 'num' 和目标值 'target' 作为输入。'backtrack' 函数用于回溯生成表达式。在回溯过程中,根据当前数字和运算符计算表达式的值,并与目标值进行比较。如果表达式的值等于目标值,则将其添加到结果列表中。

(文章为作者在学习java过程中的一些个人体会总结和借鉴,如有不当、错误的地方,请各位大佬批评指正,定当努力改正,如有侵权请联系作者删帖。)

相关推荐
程序猿chen1 分钟前
《JVM考古现场(十五):熵火燎原——从量子递归到热寂晶壁的代码涅槃》
java·jvm·git·后端·java-ee·区块链·量子计算
松韬39 分钟前
Spring + Redisson:从 0 到 1 搭建高可用分布式缓存系统
java·redis·分布式·spring·缓存
绝顶少年1 小时前
Spring Boot 注解:深度解析与应用场景
java·spring boot·后端
心灵宝贝1 小时前
Tomcat 部署 Jenkins.war 详细教程(含常见问题解决)
java·tomcat·jenkins
天上掉下来个程小白1 小时前
Redis-14.在Java中操作Redis-Spring Data Redis使用方式-操作列表类型的数据
java·redis·spring·springboot·苍穹外卖
ゞ 正在缓冲99%…1 小时前
leetcode22.括号生成
java·算法·leetcode·回溯
写代码的小王吧1 小时前
【Java可执行命令】(十)JAR文件签名工具 jarsigner:通过数字签名及验证保证代码信任与安全,深入解析 Java的 jarsigner命令~
java·开发语言·网络·安全·web安全·网络安全·jar
伊成1 小时前
Springboot整合Mybatis+Maven+Thymeleaf学生成绩管理系统
java·maven·mybatis·springboot·学生成绩管理系统
Song2 小时前
JVM 学习计划表(2025 版)
jvm·学习
一人の梅雨2 小时前
化工网平台API接口开发实战:从接入到数据解析‌
java·开发语言·数据库