站長資訊網
        最全最豐富的資訊網站

        php求兩數組交集的三種方法詳解

        php求兩數組交集的三種方法詳解

        題目:給定兩個數組,編寫一個函數來計算它們的交集。

        示例 1:

        輸入: nums1 = [1,2,2,1],nums2 = [2,2]

        輸出: [2]

        示例 2:

        輸入: nums1 = [4,9,5], nums2 = [9,4,9,8,4]

        輸出: [9,4]

        說明:

        輸出結果中的每個元素一定是唯一的。

        我們可以不考慮輸出結果的順序。

        解法一:迭代一個數組

        思路分析:

        迭代一個數組,判斷是否存在另外一個數組

        PHP 代碼實現:

        /**  * @param Integer[] $nums1  * @param Integer[] $nums2  * @return Integer[]  */ function intersection($nums1, $nums2) {     $res = [];     for($i=0;$i<count($nums1);$i++){         if(in_array($nums1[$i],$nums2)){             $res[] = $nums1[$i];         }     }     return array_unique($res); }

        使用:

        $nums2 = [2,4,6,7,8,99]; $nums1 = [1,2,5,9,9,66,89,90,99,99]; var_dump(intersection($nums1, $nums2));

        復雜度分析:

        時間復雜度:O(mn)

        解法二:內置數組函數

        思路分析:

        使用array_intersect()函數進行取數組的交集,然后再使用array_unique()去重

        PHP 代碼實現:

        /**  * @param Integer[] $nums1  * @param Integer[] $nums2  * @return Integer[]  */ function intersection($nums1, $nums2) {     return array_unique(array_intersect($nums1,$nums2)); }

        使用:

        $nums2 = [2,4,6,7,8,99]; $nums1 = [1,2,5,9,9,66,89,90,99,99]; var_dump(intersection($nums1, $nums2));

        解法三:暴力解法

        思路分析:

        先把兩個數組合并為一個數組,再兩次循環遍歷查找

        PHP 代碼實現:

        /**  * @param Integer[] $nums1  * @param Integer[] $nums2  * @return Integer[]  */ function intersection($nums1, $nums2) {     $new_arr = array_merge(array_unique($nums1),array_unique($nums2));     $res = [];     for($i=0;$i<count($new_arr);$i++){         for($j=$i+1;$j<count($new_arr);$j++){             if($new_arr[$i] == $new_arr[$j]){                 $res[] = $new_arr[$i];             }         }     }     return array_unique($res); }

        使用:

        $nums2 = [2,4,6,7,8,99]; $nums1 = [1,2,5,9,9,66,89,90,99,99]; var_dump(intersection($nums1, $nums2));

        復雜度分析:

        時間復雜度:O(n^2)

        解法四:雙指針

        思路分析:

        先把兩個數組排序,通過雙指針往前推來進行查找

        PHP 代碼實現:

        /**  * @param Integer[] $nums1  * @param Integer[] $nums2  * @return Integer[]  */ function intersection($nums1, $nums2) {     sort($nums1);     sort($nums2);     $i = $j = 0;     $res = [];     while($i < count($nums1) && $j < count($nums2)){         if($nums1[$i] == $nums2[$j]){             $res[] = $nums1[$i];             $i++;             $j++;         }elseif($nums1[$i] < $nums2[$j]){             $i++;         }elseif($nums1[$i] > $nums2[$j]){             $j++;         }     }     return array_unique($res); }

        使用:

        $nums2 = [2,4,6,7,8,99]; $nums1 = [1,2,5,9,9,66,89,90,99,99]; var_dump(intersection($nums1, $nums2));

        復雜度分析:

        時間復雜度:O(nlogn)

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 国产精品国产三级在线专区 | 精品久久久久久中文字幕| 国产午夜精品一区二区三区小说| 国内精品久久久人妻中文字幕| 久久久精品视频免费观看| 午夜影视日本亚洲欧洲精品一区| 精品无码久久久久国产| 人妻少妇看A偷人无码精品| 亚洲精品无码不卡| 国产精品久久久久影视不卡| 亚洲国产精品无码中文字| 久久人人爽人人精品视频| 国产叼嘿久久精品久久| 欧美精品福利视频| 国产福利91精品一区二区| 国产三级精品三级在线专区1 | 91精品国产高清91久久久久久 | 99久re热视频这里只有精品6| 2022国产精品自产拍在线观看| 人人妻人人澡人人爽精品日本| 色哟哟国产精品免费观看| 国产内地精品毛片视频| 99热亚洲精品6码| 亚洲精品小视频| 中文字幕精品视频| 欧美亚洲精品在线| 亚洲国产精品lv| 亚洲精品自产拍在线观看动漫| 九九精品成人免费国产片| 国产精品久久久久久影院 | 久久99精品久久久久子伦| 亚洲欧美精品AAAAAA片| 亚洲日韩精品无码专区网站| 亚洲国产精品日韩专区AV| 亚洲国产成人a精品不卡在线| 日韩精品成人亚洲专区| 色婷婷噜噜久久国产精品12p| 亚洲国产综合精品一区在线播放 | 无码精品黑人一区二区三区 | 久久精品无码免费不卡| 欧美日韩在线精品一区二区三区激情综合|