时间:2021-05-26
一般的做法就会这样:
复制代码 代码如下:
<?php
for ($offset = 0; $offset < $length; ++$offset) {
if ($str1[$offset] !== $str2[$offset]) {
return $offset;
}
}
而问题下面给出的最佳答案是用异或操作符( ^ ),以前从来没用过这个操作符,也不知道能用到什么地方,今天算是学到。
因为一般情况下,当你对两个字符串进行异或操作的时候,相同的字符的异或结果是null(“\0”),所以我们只要找出第一个非null(“\0”)字符就可以了。
复制代码 代码如下:
<?php
$position = strspn($string1 ^ $string2, "\0");
很明显这是一个更优雅高效的方法。 另外,回答的人还附加了一个多字节字符的解决办法。
复制代码 代码如下:
<?php
function getCharacterOffsetOfDifference($str1, $str2, $encoding = 'UTF-8') {
return mb_strlen($str1, $encoding)
- mb_strlen(
mb_strcut(
$str1,
strspn($str1 ^ $str2, "\0"),
mb_strlen($str1, '8bit'),
$encoding
),
$encoding
);
}
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
c语言中strcmp比较两个字符串的大小,两个字符串相同时返回0,第一个字符串大于第二个字符串时返回一个正值,否则返回负值。 比较两个字符串的算法是:逐个比较
最长公共子串(TheLongestCommonSubstring)LCS问题就是求两个字符串最长公共子串的问题。解法就是用一个矩阵来记录两个字符串中所有位置的两
一、问题描述给定两个字符串,求解这两个字符串的最长公共子序列(LongestCommonSequence)。比如字符串1:BDCABA;字符串2:ABCBDAB
本文实例讲述了PHP中strncmp()函数比较两个字符串前2个字符是否相等的方法。分享给大家供大家参考,具体如下:PHP中的strncmp()函数用于比较两个
本文实例讲述了php比较两个字符串长度的方法。分享给大家供大家参考。具体实现方法如下:这段代码计算两个字符串的长度,然后计算其差值希望本文所述对大家的php程序