我希望能够将数学表达式/方程式发送到我的程序中并让它给出我得到的答案。我正在使用正则表达式来解码要操作的数字。这是我目前正在添加的正则表达式代码:
Matcher m = Pattern.compile(".*\\D*(\\d{1,})\\s*\\+\\s*(\\d+).*").matcher(e);
if(!m.matches()) return e;
e = ((int) Addition.add(Double.parseDouble(m.group(1)), Double.parseDouble(m.group(2)))) + "";
这适用于m.group(2)
中的第二个数字,但m.group(1)
仅返回操作符号前的最后一个数字,我尝试了几种不同的方式,这是我的最新数据,没有运气。我做错了什么?
编辑:这些是3种解决方法,它有一些我正在测试的测试输出。
public double solve(String e) {
if (!validExpression(e))
return 0;
e = e.replace(" ", "");
boolean doPar = false;
if (e.contains("(") || e.contains(")")) {
doPar = true;
int par = 0;
for (char c : e.toCharArray()) {
if (c == '(')
par++;
else if (c == ')')
par--;
}
if (par != 0)
return 0;
}
if (doPar)
e = solveParentheses(e);
e = solveSmallExpression(e);
return Double.parseDouble(e.replace("(", "").replace(")", ""));
}
private static String solveSmallExpression(String e) {
System.out.println(e);
while(e.contains("^")){
final Matcher m = Pattern.compile(".*\\D*(\\d{1,})\\s*\\^\\s*(\\d+).*").matcher(e);
if(!m.matches()) return e;
System.out.println(m.group(1) + "\t" + m.group(2));
e = ((int) Exponentiation.raise(Double.parseDouble(m.group(1)), Double.parseDouble(m.group(2)))) + "";
}
while(e.contains("/") || e.contains("*")) {
if(e.contains("/")){
final Matcher m = Pattern.compile(".*\\D*(\\d{1,})\\s*/\\s*(\\d+).*").matcher(e);
if(!m.matches()) return e;
System.out.println(m.group(1) + "\t" + m.group(2));
e = ((int) Division.divide(Double.parseDouble(m.group(1)), Double.parseDouble(m.group(2)))) + "";
}
if(e.contains("*")){
final Matcher m = Pattern.compile(".*\\D*(\\d{1,}+)\\s*\\*\\s*(\\d+).*").matcher(e);
if(!m.matches()) return e;
System.out.println(m.group(1) + "\t" + m.group(2));
e = ((int) Multiplication.multiply(Double.parseDouble(m.group(1)), Double.parseDouble(m.group(2)))) + "";
}
}
while(e.contains("-") || e.contains("+")) {
if(e.contains("-")){
final Matcher m = Pattern.compile(".*\\D*(\\d{1,})\\s*\\-\\s*(\\d+).*").matcher(e);
if(!m.matches()) return e;
System.out.println(m.group(1) + "\t" + m.group(2));
e = ((int) Subtraction.subtract(Double.parseDouble(m.group(1)), Double.parseDouble(m.group(2)))) + "";
}
if(e.contains("+")){
final Matcher m = Pattern.compile(".*\\D*(\\d{1,})\\s*\\+\\s*(\\d+).*").matcher(e);
if(!m.matches()) return e;
System.out.println(m.group(1) + "\t" + m.group(2));
e = ((int) Addition.add(Double.parseDouble(m.group(1)), Double.parseDouble(m.group(2)))) + "";
}
}
System.out.println(e);
System.out.println();
return e;
}
private static String solveParentheses(String e) {
while (e.contains("(") && e.contains(")")) {
int start = -1;
int end = -1;
for(int i = 0; i < e.length(); i++) {
char c = e.charAt(i);
if(c == '(')
start = i + 1;
else if(c == ')')
end = i;
}
String sub = e.substring(start, end);
if(sub.contains("(") && sub.contains(")"))
sub = solveParentheses(sub);
sub = solveSmallExpression(sub);
e = e.replace(e.subSequence(start - 1, end + 1), sub);
}
return e;
}
private static boolean validExpression(String e) {
for (char c : e.toCharArray()) {
if (!Character.isDigit(c) && c != '(' && c != ')' && c != '^' && c != '+' && c != '-' && c != '/' && c != '*' && c != ' ')
return false;
}
return true;
}
当我打印时:
System.out.println((new ExpressionSolver()).solve("(24 * 100) - (24 / 12)"));
这是输出:
24/12
4 12
0
24*100
4 100
400
400-0
0 0
0
0.0
答案 0 :(得分:1)
。*是贪婪的,会吃完整个字符串然后回滚,直到它碰到匹配的东西。由于你可以出现0次非数字(\ D *)并且需要至少一个数字和加号,一旦它回滚足够远,正则表达式将匹配。
您可以使用“。*?”来解决此问题。相反,一个不情愿的操作员,它抓住尽可能少的字符。
答案 1 :(得分:0)
为什么不在两个组中使用相同的组声明?
表示使用(\ d +)