码迷,mamicode.com
首页 > 编程语言 > 详细

没有括号的算式 面试算法(四)

时间:2019-10-30 22:28:24      阅读:368      评论:0      收藏:0      [点我收藏+]

标签:bst   sp2   ret   turn   tst   new   举例   增加   class   

import java.util.Scanner;

public class Test {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        String next = scanner.next();
        System.out.println(test(next));
    }
    /**
     * 有一个写在黑板上的加减法算式,运算符只包含加号、减号和括号,但其中的括号被清洁工擦去了。现在需要你写一个算法计算这个算式括号被擦去之前的可能的最小结果值。
     * <p>
     * 输入:
     * 仅有一行,被擦去括号后的算式
     * <p>
     * 输入约束:
     * 算式最多有50个字符,且其中仅包含0-9和+、-
     * 算式的第一个字符一定是数字
     * 算式中不会连续出现两个运算符
     * 算式中每个整数最多有5位
     * <p>
     * 输出:
     * 一个整数:即括号被擦去之前,该算式可能的最小结果值
     * <p>
     * 举例1:
     * 输入:
     * 55-50+40
     * 输出:
     * -35
     * 解释:
     * 通过增加括号,该算式有两种可能的结果:55-50+40=45和55-(50+40)=-35
     * <p>
     * 举例2:
     * 输入:
     * 10+20+30+40
     * 输出:
     * 100
     * 解释:
     * 由于输入中没有减号,因此无论怎么加括号,结果也只能是100
     * <p>
     * 举例3:
     * 输入:
     * 00009-00009
     * 输出:
     * 0
     * 解释:注意算式中的整数可能有前导0.
     *
     * @param str
     * @return
     */
    static int test(String str) {
        String[] split = str.split("-");
        String retStr = "";
        for (int i = 0; i < split.length; i++) {
            if (split[i].indexOf("+") != -1) {
                String[] sp2 = split[i].split("\\+");
                int s = Integer.parseInt(sp2[0]);
                for (int c = 1; c < sp2.length; c++) s += Integer.parseInt(sp2[c]);
                retStr += "-" + s;
            } else retStr += "-" + split[i];
        }
        if (retStr.substring(0, 1).equals("-")) retStr = retStr.substring(1);
        String[] split1 = retStr.split("-");
        int n = Integer.parseInt(split1[0]);
        for (int i = 1; i < split1.length; i++) n -= Integer.parseInt(split1[i]);
        return n;
    }
}

  

没有括号的算式 面试算法(四)

标签:bst   sp2   ret   turn   tst   new   举例   增加   class   

原文地址:https://www.cnblogs.com/412013cl/p/11768268.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!