dti70601 2009-06-05 17:40
浏览 31
已采纳

需要帮助优化php字符串差异功能

I created this function and it works on small strings, but for longer strings it times-out. I'm looking for a way to make the function work faster and not timeout, or a better way to accomplish what I want.

function find_diffs($string1, $string2)
{
    $array1 = preg_split("/\b/", $string1);
    $array2 = preg_split("/\b/", $string2);
    $array3 = array();


    for($i=0, $j=0; $i < count($array1) || $j < count($array2); $i++, $j++)
    {
        while(badchars($array1, $i))
        {
            $i++;
        }
        while(badchars($array2, $j))
        {
            $j++;
        }

        if($array1[$i] != $array2[$j])
        {
            //-------------------------Find Subtractions--------------------//
            $k = $i;
            while($array1[$i] != $array2[$j])
            {
                $i++;
                if($i == count($array1))
                {
                    $end = true;
                    break;
                }
                while(badchars($array1, $i))
                {
                    $i++;
                }
            }
            if($end)
            {
                //-------------------------Find Additions--------------------//
                $end = false;
                $i = $k;
                $k = $j;
                while($array1[$i] != $array2[$j])
                {
                    $j++;
                    if($j == count($array2))
                    {
                        $end = true;
                        break;
                    }
                    while(badchars($array2, $j))
                    {
                        $j++;
                    }
                }
                if($end)
                {
                    //-------------------------Find Changes--------------------//
                    $end = false;
                    $j = $k;
                    $l = $i;
                    while($array1[$i] != $array2[$j])
                    {

                        $k = $j;
                        while($array1[$i] != $array2[$j])
                        {
                            $j++;
                            if($j == count($array2))
                            {
                                $end = true;
                                break;
                            }
                            while(badchars($array2, $j))
                            {
                                $j++;
                            }
                        }

                        if($end)
                        {
                            $j = $k;
                            $i++;
                            while(badchars($array1, $i))
                            {
                                $i++;
                            }
                            while(badchars($array2, $j))
                            {
                                $j++;
                            }
                        }
                        else
                        {
                            $array3[] = array($l,$i,'-');
                            $array3[] = array($k,$j,'+');
                        }
                        if($i == count($array1))
                        {
                            $end = true;
                            break;
                        }
                        if($j == count($array2))
                        {
                            $end = true;
                            break;
                        }
                        $end=false;
                    }
                    if($end)
                    {
                            break;          
                    }
                    else
                    {
                        $array3[] = array($l,$i,'-');
                        $array3[] = array($k,$j,'+');
                    }   
                    //---------------------End Find Changes--------------------//
                }
                else
                {
                    $array3[] = array($k,$j,'+');
                }
            }
            else
            {
                $array3[] = array($k,$i,'-');
            }

        }
    }

    $array3[] = array(0,count($array1),'=');
    return array($array1,$array2,$array3);
}
  • 写回答

1条回答 默认 最新

  • dravpuso44681 2009-06-05 17:44
    关注

    Don't reinvent the wheel. This is the sort of thing that is easy to get wrong and hard to get right.

    Check out the Text_Diff Pear Package. I have used it for this sort of thing and it is very well done.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 企业资源规划ERP沙盘模拟
  • ¥15 前端echarts坐标轴问题
  • ¥15 CMFCPropertyPage
  • ¥15 ad5933的I2C
  • ¥15 请问RTX4060的笔记本电脑可以训练yolov5模型吗?
  • ¥15 数学建模求思路及代码
  • ¥50 silvaco GaN HEMT有栅极场板的击穿电压仿真问题
  • ¥15 谁会P4语言啊,我想请教一下
  • ¥15 这个怎么改成直流激励源给加热电阻提供5a电流呀
  • ¥50 求解vmware的网络模式问题 别拿AI回答