О проектеГостеваяКарта сайта

Предложишь лучшее решение - получишь 100 рублей!

Поиск совпадающих подстрок в двух массивах

Задача:  найти совпадающие подстроки в двух массивах.

Пример обрабатываемого кода


Array
(
    [0] => 1123
    [1] => 222 word2
    [2] => 123 word5 456
    [3] => word2 : 5678
    [4] => word7: 222
    [5] => word8: 8890
)
Array
(
    [0] => word1
    [1] => word2
    [2] => 222
    [3] => 123
)

Решение

PHP

<?php
$array1 = array(
      "1123",
      "222 word2",
      "123 word5 456",
      "word2 : 5678",
      "word7: 222",
      "word8: 8890"
      );
$array2 = array(
      "word1",
      "word2",
      "222",
      "123",
      );
   
foreach($array1 as $arr1){
      foreach($array2 as $arr2){
         $pos = strpos($arr1, $arr2);             
                if($pos !== FALSE)
                echo $arr2." ===> ".$arr1."<br />";
      }
   }
?>
 

Результатом работы кода будет

 

123 ===> 1123
word2 ===> 222 word2
222 ===> 222 word2
123 ===> 123 word5 456
word2 ===> word2 : 5678
222 ===> word7: 222


Рейтинг:

Теги: PHP массив подстрока

Если вы знаете более оригинальное, красивое, ЛУЧШЕЕ решение этой задачи, у вас есть шанс заработать 100 рублей!!! Если ваше решение будет признано лучшим, деньги ваши! Мы гарантируем выплату!

PHP

 

Последние комментарии
  • phpguru

    Функция отличная только надо бы добавить для utf8 кодировку обработать строку, а то не все понимают как сделать подобное!
    $str = iconv_strlen($str,'UTF-8');
    Я так считаю!
    13-12-2013 в 12:59:38 ID# 454 посмотреть...


  • SnipCode.ru

    Возможно Вы правы, непонятно только зачем тут iconv_strlen (((
    13-12-2013 в 13:02:55 ID# 455 посмотреть...


  • Сергей

    поторопился, так надо в конце, пардон.
        return $v['pass'];
        }
    return FALSE;
    }

    02-12-2013 в 23:33:41 ID# 377 посмотреть...


  • Сергей

    Думаю все же логичней использовать foreach, т.к. можно промахнуться с ключами, а если массив ассоциативный (я раньше делал ключ = дата и время регистрации), то вообще работать не будет.
     
    function search($array,$login)
    {
       foreach ($array as $k=>$v)
        if($v['login'] == $login){
        return $v['pass'];
        }
    }
    return FALSE;
    Так, на минутку.
    Время исполнения смысла не имеет, авторизация используется 1 раз, если юзер не параноик)))

    02-12-2013 в 23:33:41 ID# 376 посмотреть...


  • Пабло

    Как сделана ваша система рейтинга,с учетом количеством людей,проголосовавших?
    11-11-2013 в 17:04:39 ID# 207 посмотреть...


  • SnipCode.ru

    ну...вобщем то все просто: берем общую оценку, делим на кол-во проголосовавших, получаем рейтинг
    11-11-2013 в 17:07:06 ID# 208 посмотреть...


  • Пабло

    Да,просто у меня возникли проблемы,при сохранении данных,в бд и отображение количество проголосовавших людей,у вас где нибудь на сайте описано как это сделано или будет?
     
    Мне нужна система рейтинга точно такая же как у вас=)
    11-11-2013 в 17:10:56 ID# 209 посмотреть...


  • KorniloFF

    Приведенный код обрезает до первой точки в строке, в случае, если в ней будет их несколько, что не соответствует теме.
    Вот код, обрезающий до последней точки:

    PHP

    $title= preg_replace("/([\s\S.]+)\.\w+$/","$1",$str)
     

    10-11-2013 в 10:45:29 ID# 205 посмотреть...


  • Виктор

    Все отлично работает! Извините , у меня есть задача отрезать после второй и до второй запятой , что нужно поправить в первом примере?
    Спасибо!
    30-09-2013 в 20:34:07 ID# 204 посмотреть...