java利用栈的思想判断字符串中括号是否成对,通过正则表达式获取字符串表达式中数字方法

package com.bh;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

import org.apache.commons.collections.ArrayStack;

//import com.googlecode.aviator.AviatorEvaluator;

//import java.text.SimpleDateFormat;
//import java.util.Date;

//import com.googlecode.aviator.AviatorEvaluator;

public class Test {

	/**
	 * 利用栈的思想判断字符串表达式中括号是否成对。 栈先进后出
	 * 
	 * @param expression
	 * @return
	 */
	public static boolean valid(String expression) {
		// 定义一个栈数据结构
		ArrayStack stack = new ArrayStack(expression.length());
		System.out.println(stack);
		// 将符号按对应关系放到map里面,方便后面根据开始符号取对应的结束符号
		Map<String, String> map = new HashMap<>();
//		map.put("{", "}");
//		map.put("[", "]");
		map.put("(", ")");
		char[] exp = expression.toCharArray();
		for (int i = 0; i < exp.length; i++) {
			// 如果是开始符号,则压入栈
//			if (exp[i] == '{' || exp[i] == '[' || exp[i] == '(') {
//				stack.push(exp[i]);
//			}
			if (exp[i] == '('){
				if(i>0){
					if(Pattern.matches("\\d",String.valueOf(exp[i-1]))){//(括号前面不能跟数字
						return false;
					}
					if(Pattern.matches("\\d",String.valueOf(exp[i-1]))){//(括号前面不能跟And或者or
						return false;
					}
				}
				stack.push(exp[i]);
			}
			System.out.println(exp[i]);
			// 如果是结束符号,则判断当前栈顶元素和该结束符号是否是对应关系
			if (exp[i] == ')'){
				if(i+1<exp.length){
					if(Pattern.matches("\\d",String.valueOf(exp[i+1]))){//)括号后面不能跟数字
						return false;
					}
				}
				if(i>0){
					if(String.valueOf(exp[i-1]).equals(")")){//不能出现连在一起的括号
						return false;
					}
				}
				if (stack.isEmpty()) {
					return false;
				}
				String c = String.valueOf(stack.pop());
				if (exp[i] != map.get(c).toCharArray()[0]) {
					return false;
				}
			}
		}
		if (!stack.isEmpty()) {
			return false;
		}
		return true;
	}

	/**
	 * 通过正则表达式获取字符串表达式中数字
	 * 
	 * @return
	 */
	public static List<String> getExpressionNum(String expression) {
		expression = expression.replace(" ", "");
		Pattern pattern = Pattern.compile("\\d+");
		Matcher matcher = pattern.matcher(expression);
		List<String> strList = new ArrayList<>();
		while (matcher.find()) {
			System.out.println(matcher.group());
			strList.add(matcher.group());
		}
		return strList;
	}

	public static void  jiaoyan(String expression){
		System.out.println("expression"+expression);
		expression = expression.replace(" ", "");
//		Pattern pattern = Pattern.compile("([a-z]+)");
		Pattern pattern = Pattern.compile("\\W+");
		Matcher matcher = pattern.matcher(expression);
		List<String> strList = new ArrayList<>();
		System.out.println(matcher);
		while (matcher.find()) {
			System.out.println(matcher.group());
			strList.add(matcher.group());
		}
	}
	
	public static void main(String[] args) {

	}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值