zoukankan      html  css  js  c++  java
  • 正则表达式中的反向引用

    1.反向引用需要使用到分组,分组就是使用()括起来的部分为一个整体,在进行分组匹配时的原则是:由外向内,由左向右


    2.反向引用如:1,2等
              1:表示的是引用第一次匹配到的()括起来的部分
              2:表示的是引用第二次匹配到的()括起来的部分
     
              (1)例:
                   String regex = "^(\d)\1$";
                   首先这里是匹配两位,d一位,1又引用d一位 这里的1会去引用(d)匹配到的内容,因为(d)是第一次匹配到的内容。
                  如:str = "22"时,(\d)匹配到2,所以1引用(\d)的值也为2,所以str="22"能匹配
                        str = "23"时,(\d)匹配到2,因为1引用(\d)的值2,而这里是3,所以str="23"不能匹配
              (2)例:
                   String regex = "^(\d)\1[0-9](d)1{2}";
                   注意在后面第二个(d)1{2}中的1,这里的1并不会去匹配他前面的(d),而是匹配第一个(\d),
                   如:第一个(d)为3时,则第一个1也为3,同样最后那个1也为3,所以结果可以是335933,332533
                        而不是336444,339888
                 
     
              (3)例:
                   String regex = " ^(d)1[0-9](d)2{2}$";
                   这里使用了2引用第二次匹配到的分组,这里第二次匹配的分组为2前面的(d), 这里的{2}指的是2的值出现两次
                   如:第一个(d)为4时,1引用第1个(d)也为4,第二个(d)为5时,2引用第二个(d)为5,所以结果可以是:447555,440222
              
              
              
     
              (4)例:
                   String regex = " ^((d)3)1[0-9](d)2{2}$";
                   当匹配中的分组有嵌套时,是从外向里匹配的,其次在由左向右匹配
                   这里主要是分析匹配到分组的顺序,首先匹配((d)3)这整个部分,其次匹配((d)3)里面的(d),第三次匹配时最后一个2前面的(d)
                   如:如((d)3)中的(d)为2时,((d)3)的值为23,此时1为((d)3)的值1,而2引用((d)3)中的(d)的值3,第三个(d)为5时,此时3引用第三个(d)的值5,所以结果可以有:23238522,23230522,
              
                   
  • 相关阅读:
    【类似N^N做法的斐波那契数列】【HDU1568】 Fibonacci
    【取对数+科学计数法】【HDU1060】 N^N
    【枚举+数学】【HDU1271】整数对 难度:五颗星
    【欧拉函数】【HDU1286】 找新朋友
    【筛素数表证明】【O[n]】
    【沙茶了+筛选保存最大质因数】【HDU2136】Largest prime factor
    【gcd+数学证明】【HDU1722】 CAKE
    【贪心】【HDU3177】 搬家问题
    HDU2093 字符串2种不错的读入思路
    tf.argmax()
  • 原文地址:https://www.cnblogs.com/1549983239yifeng/p/14067260.html
Copyright © 2011-2022 走看看