计算任意字符串算式的结果

2020-08-12  本文已影响0人  雨影

该算法不包含括号运算!
主要思路是利用递归算法
1、先把减法变成加法,把除法变成乘法
2、截取优先级低的算式,将优先级高的算式递归调用本身算出结果

直接上代码


func calcuterResult(input: String) -> Double {
    let newStr = input.replacingOccurrences(of: "-", with: "+-") //减法变加法
        .replacingOccurrences(of: "/", with: "*1/") //除法变乘法
    return calcuter(input: newStr)
}

func calcuter(input: String) -> Double {

    if input.contains("+") { // 加法运算

        var result = 0.0
        let values = input.components(separatedBy: "+") 
        for value in values {

            guard !value.isEmpty else { continue }
            if let num = Double(value) {
                result = result + num
            } else {
                result = result + calcuter(input: value)
            }
        }
        return result

    } else { // 乘法结果

        var result = 1.0
        let values = input.components(separatedBy: "*")
        for value in values {

            guard !value.isEmpty else { continue }
            if let num = Double(value) {
                result = result * num
            } else {
                // "1/2" ,"1/5"
                let coms = value.components(separatedBy: "/")
                if let num = coms.last {
                    result = result * 1 / (Double(num) ?? 1)
                }
            }
        }
        return result
    }
}


上一篇下一篇

猜你喜欢

热点阅读