给出一个布尔表达式的字符串,比如:true or false and false,表达式只包含true,false,and和or,现在要对这个表达式进行布尔求值,计算结果为真时输出true、为假时输出false,不合法的表达时输出error(比如:true true)。表达式求值是注意and 的优先级比 or 要高,比如:true or false and false,等价于 true or (false and false),计算结果是 true。
给出一个布尔表达式的字符串,比如:true or false and false,表达式只包含true,false,and和or,现在要对这个表达式进行布尔求值,计算结果为真时输出true、为假时输出false,不合法的表达时输出error(比如:true true)。表达式求值是注意and 的优先级比 or 要高,比如:true or false and false,等价于 true or (false and false),计算结果是 true。
输入第一行包含布尔表达式字符串s,s只包含true、false、and、or几个单词(不会出现其它的任何单词),且单词之间用空格分隔。 (1 ≤ |s| ≤ 103).
输出true、false或error,true表示布尔表达式计算为真,false表示布尔表达式计算为假,error表示一个不合法的表达式。
and
error
true and false
false
true or false and false
true
import java.util.*; public class Main{ public static String calcSub(String n1, String n2, String ops){ if(ops.equals("and")){ if(n1.equals("true") && n2.equals("true")){ return "true"; }else{ return "false"; } }else{ if(n1.equals("false") && n2.equals("false")){ return "false"; }else{ return "true"; } } } public static void calc(Stack<String> op, Stack<String> num){ String n1 = num.pop(); String n2 = num.pop(); String ops = op.pop(); num.push(calcSub(n1, n2, ops)); } //表达式求值 public static String bds(String a){ Stack<String> num = new Stack<>(); Stack<String> op = new Stack<>(); String[] s = a.split(" "); int flag = 0; //数 for(int i=0;i<s.length;i++){ if(flag == 0) { if (!s[i].equals("true") && !s[i].equals("false")) { return "error"; }else{ num.push(s[i]); flag = 1; } }else{ if (!s[i].equals("and") && !s[i].equals("or")) { return "error"; }else{ //控制优先级 if(!op.empty() && "and".equals(op.peek())){ calc(op, num); } op.push(s[i]); flag = 0; } } } //这里为了解决 “true and” 最后是操作符的情况 if(flag == 0){ return "error"; } while(true){ if(op.empty()){ return num.pop(); } calc(op, num); } } public static void main(String[] args){ Scanner scanner=new Scanner(System.in); System.out.println(bds(scanner.nextLine())); } }
简简单单两小时,太菜了,害~ 使用一个栈,只存“true”、“false”、“or”。 如果第一个字符串是true或false,就入栈,这样后面就不用频繁判断栈空了;否则返回error 循环判断字符串数组 遇到“#” 跳过本次循环 遇到T F 如果栈顶是or,则入栈 否则返回error 遇到or 如果stack不为空 并且栈顶不为or 则入栈; 否则error 遇到and 如果stack为空或者i+1越界或者i+1不是T F,则返回error; 否则弹出一个元素,与下一个元素and运算,将下一个结果标记为“#”。将结果压入栈 到达字符串数组末尾,弹出所有元素并进行or运算,将结果返回
import java.util.*; public class Main{ public static void main(String[] args){ Scanner sc = new Scanner(System.in); String[] s = sc.nextLine().split(" "); sc.close(); String str = helper(s); System.out.println(str); } public static String helper(String[] s){ Deque<String> stack = new LinkedList<>(); String tmp = ""; if (s[0].equals("true") || s[0].equals("false")) { stack.push(s[0]); }else { return "error"; } for (int i = 1; i < s.length; i++) { String s1 = s[i]; if(s1.equals("#")){ continue; } if (stack.peek().equals("true") || stack.peek().equals("false")) { if (s1.equals("or") && i + 1 < s.length) { stack.push(s1); }else if (s1.equals("and") && i + 1 < s.length) { tmp = stack.pop(); boolean t1 = Boolean.parseBoolean(tmp) && Boolean.parseBoolean(s[i+1]); stack.push(String.valueOf(t1)); s[i+1] = "#"; }else { return "error"; } }else { //栈顶是or if (s1.equals("true") || s1.equals("false")) { stack.push(s1); }else { return "error"; } } } if (!stack.isEmpty() || stack.peek().equals("true") || stack.peek().equals("false")){ tmp = stack.pop(); boolean res = Boolean.parseBoolean(tmp); while (!stack.isEmpty()){ tmp = stack.pop(); if (!tmp.equals("or")) { res |= Boolean.parseBoolean(tmp); } } return String.valueOf(res); }else { return "error"; } } }
import java.util.*; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String s = sc.nextLine(); String[] exp = s.split(" "); System.out.println(method(exp)); } private static String method(String[] s) { Stack<String> stack = new Stack<>(); if ("or".equals(s[0]) ||"or".equals(s[s.length - 1]) || "and".equals(s[0]) ||"and".equals(s[s.length - 1])) { return "error"; } stack.push(s[0]); for (int i = 1; i < s.length; i++) { if ("or".equals(s[i]) || "and".equals(s[i])) { if ("or".equals(s[i - 1]) || "and".equals(s[i - 1])) { return "error"; } if ("and".equals(s[i])) { String w = stack.pop(); String p = s[i+1]; if (w.equals(p) && "true".equals(w)) { stack.push("true"); } else { stack.push("false"); } i++; } } else { if ("true".equals(s[i - 1]) || "false".equals(s[i - 1])) { return "error"; } stack.push(s[i]); } } while (!stack.isEmpty()) { if ("true".equals(stack.pop())) { return "true"; } } return "false"; } }
import java.util.*; public class Main{ public static void main(String[] strs){ String str = cal(); System.out.println(str); } public static String cal(){ Scanner sc = new Scanner(System.in); String str = sc.nextLine().trim(); // String str = "false&nbs***bsp;true and false"; String[] words = str.split(" "); // System.out.println(Arrays.toString(words)); Stack<Integer> stack = new Stack<>(); for(int i = 0; i < words.length; i++){ if(words[i].equals("true")){ stack.push(1); }else if(words[i].equals("false")){ stack.push(0); }else if(words[i].equals("and")){ if(!stack.isEmpty() && stack.peek() != 2 && i != words.length - 1 && (words[i + 1].equals("true") || words[i + 1].equals("false"))){ int val = words[i + 1].equals("true") ? 1 : 0; stack.push(stack.pop() & val); i++; }else return "error"; }else if(words[i].equals("or")){ stack.push(2); }else return "error"; } int last = -1; while (!stack.isEmpty()){ if(last == -1){ last = stack.pop(); if(last == 2) return "error"; }else{ int or = stack.pop(); if(or != 2) return "error"; int val = 0; if(!stack.isEmpty() && stack.peek() != 2) val = stack.pop(); else return "error"; last = last | val; } } return last == 1 ? "true" : "false"; } }