Нужна помощь в оптимизации функции разницы строк php - PullRequest
1 голос
/ 05 июня 2009

Я создал эту функцию, и она работает с небольшими строками, но для более длинных строк это время ожидания. Я ищу способ заставить функцию работать быстрее, а не время ожидания, или лучший способ выполнить то, что я хочу.

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 Ответ

5 голосов
/ 05 июня 2009

Не изобретай велосипед. Это та вещь, которую легко ошибиться и трудно понять.

Проверьте пакет Text_Diff Pear. Я использовал это для такого рода вещей, и это очень хорошо сделано.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...