【贪婪与非贪婪算法】

        贪婪匹配:当正则表达式中包含能接受到重复的限定符时,通常的行为是匹配尽可能多的字符,这中匹配方式叫做贪婪匹

配。特征是一次性读入整个字符串经行匹配,每当不匹配就舍弃最右边一个字符,继续匹配,依次匹配和舍弃,直到匹配成功或

者把整个字符串舍弃为止,因此它是一种最大化数据返回,能多不会少。

@Test
	/*
	 * "%.*?%"  非贪婪匹配
	 */
	public void test4() {
		String regx = "%.*?%";  //非贪婪匹配
		String str = "%sbdddbfzh%\n %vgvcyvu%\n %ugbh%\n"; 
	    System.out.println(str.replaceAll(regx, "aaa"));
	}
	
	@Test
	/*
	 * 分组匹配
	 */
	public void test5() {
		String regx = "(%)(.*?)(%)";  //非贪婪匹配
		String str = "%sbdddbfzh% %vgvcyvu% %ugbh%"; 
	    System.out.println(str.replaceAll(regx, "$2"));  //去掉两边%% 
	    System.out.println(str.replaceAll(regx, "$1aaa$3"));  // 中间替换  两边被保留  不变
	    System.out.println(str.replaceAll(regx, "$1"));
	
	    
	    
	}

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值