计算逻辑中%的处理

介绍

我这个方法是将%以及前面的数字替换为相应的 符合正常计算的数字( 即: x% --> (x*0.01) 这里的x为任意组合)

另外写了一个测试方法 就是完成后 检验加上的左右括号是否相等,避免不必要的错误

public class Test01 {
    public static void main(String[] args) {
        String s = "1%+(2+3)%+100%+300/((2+(5+2))%+((1+5)+(2+3))%/100)+10%*5+((4+5)+5)%+(3+(2%+3)%)%+100%";
        StringBuilder sb = new StringBuilder(s);
        sb.insert(0, "+");
        String searchFor = "%";
        int index = 0;
        while ((index = sb.indexOf(searchFor, index)) != -1) {
            char[] chars = sb.toString().toCharArray();
            if (chars[index - 1] == ')') {
                sb.replace(index, index + 1, "*0.01");
                index += 5;
            } else {
                for (int i = index; i >= 0; i--) {
                    if (chars[i] == '*' || chars[i] == '/' || chars[i] == '+' || chars[i] == '-') {
                        sb.insert(i + 1, "(");
                        sb.replace(index + 1, index + 2, "*0.01)");
                        i++;
                        index += 6;
                        break;
                    }
                }
            }
            index += searchFor.length();
        }
        String substring = sb.substring(1, sb.length());

        Test01 test01 = new Test01();
        int countRight = test01.getCount("(", substring);
        int countLeft = test01.getCount(")", substring);

        System.out.println(substring);
        System.out.println("左右括号是否相等   " + (countRight == countLeft));
    }

    // 统计一个字符在字符串中出现的数量
    public int getCount(String serchFor, String str) {
        int count = 0;
        int index = 0;
        while ((index = str.indexOf(serchFor, index)) != -1) {
            count++;
            index += serchFor.length();
        }
        return count;
    }
}

结果


(100*0.01)+300/((2+(5+2))*0.01+((1+5)+(2+3))*0.01/100)+(10*0.01)*5+((4+5)+5)*0.01+(3+(2+3)*0.01)*0.01
左右括号是否相等   true

另外在推荐一种利用String类里面的方法来替换计算公式中的%

方法链接

发布了43 篇原创文章 · 获赞 36 · 访问量 2230

猜你喜欢

转载自blog.csdn.net/qq_17589751/article/details/104536345