Heim Backend-Entwicklung PHP-Problem So finden Sie nicht aufeinanderfolgende Zahlen in einer Zahlenfolge in PHP

So finden Sie nicht aufeinanderfolgende Zahlen in einer Zahlenfolge in PHP

Apr 05, 2023 am 10:31 AM

In der PHP-Entwicklung ist es oft notwendig, diskontinuierliche Zahlen in einer Zahlenfolge zu finden. Wie kann diese Anforderung schnell und effizient umgesetzt werden? Dieser Artikel wird es Ihnen im Detail erklären.

1. Problemhintergrund

Suchen Sie diskontinuierliche Zahlen in einer Zahlenfolge, dh finden Sie die Zahlen, die nach einer bestimmten Zahl einen bestimmten Abstand zur nächsten Zahl haben. Wenn beispielsweise eine Sequenz [1, 2, 6, 7, 9, 12, 15, 17] gegeben und nach diskontinuierlichen Zahlen gesucht wird, lautet der Rückgabewert unter der Annahme, dass das Intervall 4 ist, [2, 9, 17].

2. Problemanalyse

Um diese Anforderung zu erfüllen, müssen wir die gesamte Zahlenfolge durchlaufen und für jede Zahl die folgende Verarbeitung durchführen:

  1. Überprüfen Sie, ob die Differenz zwischen der aktuellen Zahl und der vorherigen Zahl gleich der angegebenen ist Wenn sie gleich sind, bedeutet dies, dass diese Zahl eine der diskontinuierlichen Zahlen ist. Wenn sie nicht gleich sind, wird die Zahl als aktuelle Zahl aufgezeichnet.
  2. Fügen Sie die aufgezeichneten Zahlen zu einem Ergebnisarray hinzu und geben Sie schließlich das Ergebnisarray zurück.

In einer spezifischen Implementierung können die folgenden Methoden verwendet werden:

  1. Definieren Sie ein $result-Array zum Speichern diskontinuierlicher Zahlen.
  2. Definieren Sie eine $ previous-Variable, um die vorherige Nummer aufzuzeichnen.
  3. Durchlaufen Sie die Zahlenfolge und verarbeiten Sie jede Zahl.

    1. Wenn die Differenz zwischen dieser Zahl und der vorherigen Zahl dem angegebenen Intervall entspricht, fügen Sie die Zahl dem $result-Array hinzu.
    2. Andernfalls notieren Sie die Zahl als $ previous.
  4. Gibt das $result-Array zurück.

Der spezifische Implementierungscode lautet wie folgt:

function findDiscontinuousNumbers($nums, $interval) {
    $result = [];
    $previous = null;
    foreach ($nums as $num) {
        if (!is_null($previous) && $num - $previous == $interval) {
            $result[] = $num;
        }
        $previous = $num;
    }
    return $result;
}

$nums = [1, 2, 6, 7, 9, 12, 15, 17];
$interval = 4;
$result = findDiscontinuousNumbers($nums, $interval);
print_r($result);
Nach dem Login kopieren

3. Codeoptimierung

Die obige Implementierung kann die Anforderungen bereits erfüllen, ist jedoch im tatsächlichen Einsatz möglicherweise nicht effizient. Betrachten Sie die folgende Optimierung:

  1. Wenn eine Zahl als diskontinuierliche Zahl aufgezeichnet wurde, können die folgenden Zahlen nicht fortlaufend damit sein, daher kann $ previous vor der nächsten Verarbeitung auf diese diskontinuierliche Zahl gesetzt werden.
  2. Bei der Suche nach digitalen Sequenzen mit großen Unterschieden kann während des Durchlaufvorgangs die Position der letzten diskontinuierlichen Zahl aufgezeichnet und die nächste Suche direkt von dieser Position aus verarbeitet werden, wodurch unnötige Durchläufe reduziert werden können.

Der optimierte Code lautet wie folgt:

function findDiscontinuousNumbers($nums, $interval) {
    $result = [];
    $previous = null;
    $last_discontinuous_index = null; // 上一次不连续数字的索引位置
    for ($i = 0; $i < count($nums); ) {
        if (!is_null($previous)) {
            if ($nums[$i] - $previous == $interval) {
                $result[] = $nums[$i];
            } else {
                $previous = $nums[$i];
                $last_discontinuous_index = $i;
            }
        } else {
            $previous = $nums[$i];
            $last_discontinuous_index = $i;
        }
        $i += ($i == $last_discontinuous_index + 1) ? 1 : $interval;
    }
    return $result;
}

$nums = [1, 2, 6, 7, 9, 12, 15, 17];
$interval = 4;
$result = findDiscontinuousNumbers($nums, $interval);
print_r($result);
Nach dem Login kopieren

IV. Zusammenfassung

Dieser Artikel stellt kurz die Methode zum Finden diskontinuierlicher Zahlen in PHP vor und gibt die grundlegende Implementierung. Im tatsächlichen Einsatz sollten geeignete Implementierungsmethoden und Optimierungsmaßnahmen je nach Bedarf ausgewählt werden, um eine bessere Leistung und Wirkung zu erzielen.

Das obige ist der detaillierte Inhalt vonSo finden Sie nicht aufeinanderfolgende Zahlen in einer Zahlenfolge in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

PHP 8 JIT (Just-in-Time) -Kompilation: Wie es die Leistung verbessert. PHP 8 JIT (Just-in-Time) -Kompilation: Wie es die Leistung verbessert. Mar 25, 2025 am 10:37 AM

Die JIT -Kompilierung von PHP 8 verbessert die Leistung, indem häufig ausgeführte Code in den Maschinencode zusammengestellt wird, um Anwendungen mit schweren Berechnungen zugute und die Ausführungszeiten zu reduzieren.

PHP Secure-Datei-Uploads: Verhindern von Sicherheitslücken im Zusammenhang mit Datei. PHP Secure-Datei-Uploads: Verhindern von Sicherheitslücken im Zusammenhang mit Datei. Mar 26, 2025 pm 04:18 PM

In dem Artikel wird das Sicherung von PHP -Dateien -Uploads erläutert, um Schwachstellen wie die Code -Injektion zu verhindern. Es konzentriert sich auf die Dateitypvalidierung, den sicheren Speicher und die Fehlerbehandlung, um die Anwendungssicherheit zu verbessern.

OWASP Top 10 PHP: Beschreiben und mildern gemeinsame Schwachstellen. OWASP Top 10 PHP: Beschreiben und mildern gemeinsame Schwachstellen. Mar 26, 2025 pm 04:13 PM

In dem Artikel werden OWASP Top 10 Schwachstellen in PHP- und Minderungsstrategien erörtert. Zu den wichtigsten Problemen gehören die Injektion, die kaputte Authentifizierung und XSS mit empfohlenen Tools zur Überwachung und Sicherung von PHP -Anwendungen.

PHP -Authentifizierung & amp; Autorisierung: sichere Implementierung. PHP -Authentifizierung & amp; Autorisierung: sichere Implementierung. Mar 25, 2025 pm 03:06 PM

In dem Artikel wird die Implementierung einer robusten Authentifizierung und Autorisierung in PHP erörtert, um den nicht autorisierten Zugriff zu verhindern, Best Practices zu beschreiben und sicherheitsrelevante Tools zu empfehlen.

PHP -Verschlüsselung: Symmetrische und asymmetrische Verschlüsselung. PHP -Verschlüsselung: Symmetrische und asymmetrische Verschlüsselung. Mar 25, 2025 pm 03:12 PM

In dem Artikel wird die symmetrische und asymmetrische Verschlüsselung in PHP erörtert und ihre Eignung, Leistung und Sicherheitsunterschiede verglichen. Die symmetrische Verschlüsselung ist schneller und für Massendaten geeignet, während asymmetrisch für den sicheren Schlüsselaustausch verwendet wird.

Wie rufen Sie Daten mit PHP aus einer Datenbank ab? Wie rufen Sie Daten mit PHP aus einer Datenbank ab? Mar 20, 2025 pm 04:57 PM

In Artikel wird das Abrufen von Daten aus Datenbanken mithilfe von PHP, die Schritte, Sicherheitsmaßnahmen, Optimierungstechniken und gemeinsame Fehler bei Lösungen erfasst.

PHP -API -Rate Begrenzung: Implementierungsstrategien. PHP -API -Rate Begrenzung: Implementierungsstrategien. Mar 26, 2025 pm 04:16 PM

In dem Artikel werden Strategien zur Implementierung der API-Rate in PHP erörtert, einschließlich Algorithmen wie Token-Bucket und Leaky Bucket sowie Bibliotheken wie Symfony/Rate-Limiter. Es deckt auch die Überwachung, die dynamischen Einstellungsgeschwindigkeiten und die Hand ab

PHP -CSRF -Schutz: Wie Sie CSRF -Angriffe verhindern. PHP -CSRF -Schutz: Wie Sie CSRF -Angriffe verhindern. Mar 25, 2025 pm 03:05 PM

In dem Artikel werden Strategien erörtert, um CSRF-Angriffe in PHP zu verhindern, einschließlich der Verwendung von CSRF-Token, selben Cookies und ordnungsgemäßem Sitzungsmanagement.

See all articles