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
                  );
    }



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

  • 相关阅读:
    Homework template (latex)
    Basic skill of searching
    国庆第三次集训: 2012 ACM-ICPC Asia Regional Contest Chengdu Site
    新学期随笔
    暑期集训感想
    暑期集训 DP 篇
    POJ 1195 Mobile Phones 二维树状数组
    51Nod1246 罐子和硬币,不能均分的题
    一维战舰,一道考区间的好题
    51NOD 1268 和为K的组合 搜索水题
  • 原文地址:https://www.cnblogs.com/sunscheung/p/4839440.html
Copyright © 2011-2022 走看看