zoukankan      html  css  js  c++  java
  • 求两个字符串第一个不等的字符位置(长度)

    开发中遇到的需求:

    1、首先写的功能函数如下

    //求两个字符串第一个不等的字符位置(长度)  2014.9.16

    function equalPostion($str1,$str2){  //这里字符串都是大小写、长度是统一的,根据需要可以增加判断
        $num=0;
        //$a[0]='3001:3def::2001:1111';
        //$a[1]='2001:3def::2003:ffff';
        for($i=0;$i<strlen($str1);$i++){
            while($str1[$i]!=$str2[$i]){
                return $num;
            }
            $num=$num+1;
        }

    }


    2、//再次会有这样的想法:

    for ($offset = 0; $offset < $length; ++$offset) {
        if ($str1[$offset] !== $str2[$offset]) {
            return $offset;
        }

    3、推荐的方法,利用php自有的函数,加上异或操作。如下:

    $position = strspn($str1 ^ $str2, ""); 

    //对于多字节的中文可以采用如下方法:

    function getCharacterOffsetOfDifference($str1, $str2, $encoding = 'UTF-8') {
         return mb_strlen($str1, $encoding)
                - mb_strlen(
                      mb_strcut(
                          $str1,
                          strspn($str1 ^ $str2, ""),
                          mb_strlen($str1, '8bit'),
                          $encoding
                      ),
                      $encoding
                  );
    }



    版权声明:本文为博主原创文章,未经博主允许不得转载。

  • 相关阅读:
    python里面的xlrd模块详解以及样例
    关于DOM的事件操作
    python正则表达式去除文本中间的换行符
    文本分类问题汇总
    pip安装问题
    3NF的无损连接和保持函数依赖的分解、BCNF的无损连接的分解
    Pyhton基本图形绘制
    软件过程模型
    常见算法的时间与空间复杂度
    随笔
  • 原文地址:https://www.cnblogs.com/sunscheung/p/4839440.html
Copyright © 2011-2022 走看看