Rumah  >  Soal Jawab  >  teks badan

putaran tatasusunan php

<p>Daripada dua tatasusunan integer ini, bagaimanakah saya boleh menentukan sama ada tatasusunan kedua ialah versi pusingan tatasusunan pertama dan fungsi php yang manakah diperlukan? </p> <p>Contoh: Tatasusunan asal A=[1,2,3,4,5,6,7,8] Putar tatasusunan B=[6,7,8,1,2,3,4,5]</p> <p>Dalam contoh ini, semua nombor dalam tatasusunan A diputar 5 kedudukan ke kanan. </p>
P粉043295337P粉043295337435 hari yang lalu546

membalas semua(1)saya akan balas

  • P粉111627787

    P粉1116277872023-09-04 00:34:22

    Tiada fungsi terbina dalam, tetapi anda boleh memutar setiap kedudukan dan membandingkan jika ia betul.

    $isRotated = function (array $original, array $maybeRotated): bool {
        $originalCount     = count($original);
        $maybeRotatedCount = count($maybeRotated);
        if ($originalCount !== $maybeRotatedCount || $original === $maybeRotated) {
            return false;
        }
    
        for ($i = 0; $i < $originalCount; $i++) {
            $original[] = array_shift($original);
            if ($original === $maybeRotated) {
                return true;
            }
        }
    
        return false;
    };
    
    echo $isRotated([1, 2, 3, 4, 5, 6, 7, 8], [6, 7, 8, 1, 2, 3, 4, 5]) ? 'true' : 'false', PHP_EOL;
    echo $isRotated([1, 2, 3, 4, 5, 6, 7, 8], [1, 2, 3, 4, 5, 6, 7, 8]) ? 'true' : 'false', PHP_EOL;
    echo $isRotated([1, 2, 3, 4, 5, 6, 7, 8], [2, 3, 4, 5, 6, 7, 8, 1]) ? 'true' : 'false', PHP_EOL;

    Output

    true
    false
    true

    balas
    0
  • Batalbalas