Rumah > pembangunan bahagian belakang > tutorial php > Kongsi penyelesaian PHP yang menarik kepada masalah algoritma

Kongsi penyelesaian PHP yang menarik kepada masalah algoritma

藏色散人
Lepaskan: 2023-04-11 16:36:01
ke hadapan
1468 orang telah melayarinya

Artikel ini membawakan anda pengetahuan yang berkaitan tentang PHP terutamanya ia berkongsi dengan anda penyelesaian yang menarik untuk masalah algoritma. Terdapat contoh kod yang berminat boleh lihat di bawah.

Kongsi penyelesaian PHP yang menarik kepada masalah algoritma

Saya baru-baru ini melihatnya di Leetcode dan ia menarik perhatian.

Pautan asal: https://leetcode.cn/problems/contains-duplicate/

Soalan

Anda diberi nombor tatasusunan integer. Mengembalikan benar jika sebarang nilai muncul sekurang-kurangnya dua kali dalam tatasusunan mengembalikan palsu jika setiap elemen dalam tatasusunan adalah berbeza.

示例 1:

输入:nums = [1,2,3,1]
输出:true

示例 2:

输入:nums = [1,2,3,4]
输出:false

示例 3:

输入:nums = [1,1,1,3,3,4,3,2,4,2]
输出:true
Salin selepas log masuk

Penyelesaian standard

    function containsDuplicate($nums) {

        foreach($nums as $val){
            if($repeat[$val] != ''){
                return true;
            }else{
                $repeat[$val] = $val;
            }
        }
        return false;

    }
Salin selepas log masuk

Penyelesaian yang menarik

Prinsip: Gulung dua dadu seberapa banyak yang perlu , jika mereka sama, bermakna terdapat pertindihan.

function containsDuplicate($nums) {
        $total = count($nums);

       for ($i=0; $i < 100000; $i++) {
           $a = mt_rand() % $total;
           $b = mt_rand() % $total;

            if($a != $b && ($nums[$a] == $nums[$b])){
                return true;
            }
       }

        return false;
    }
Salin selepas log masuk

Pembelajaran yang disyorkan: "Tutorial Video PHP"

Atas ialah kandungan terperinci Kongsi penyelesaian PHP yang menarik kepada masalah algoritma. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
php
sumber:learnku.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan