Heim > Web-Frontend > js-Tutorial > Hauptteil

Finden Sie den Peak einer Reihe zentraler Peaks in JavaScript

WBOY
Freigeben: 2023-08-24 12:21:07
nach vorne
820 Leute haben es durchsucht

在 JavaScript 中查找中心峰值数组的峰值

Center Peak Array

Wenn die folgenden Eigenschaften erfüllt sind, nennen wir das Array arr als Center Peak Array -

  • arr.length >= 3

  • Es gibt einige i und 0

    • arr[0]

    • arr[ i] > arr[i+ 1] > .. > arr[arr.length - 1]

Frage

Wir müssen eine JavaScript-Funktion schreiben, die ein numerisches Array arr als ersten und einzigen Parameter akzeptiert.

Das Eingabearray ist ein Center-Peak-Array. Unsere Funktion sollte den Peak-Index dieses zentralen Peak-Arrays zurückgeben.

Zum Beispiel, wenn die Eingabe für die Funktion

Eingabe

const arr = [4, 6, 8, 12, 15, 11, 7, 4, 1];
Nach dem Login kopieren

Ausgabe

const output = 4;
Nach dem Login kopieren

Ausgabeerklärung

ist, weil das Element am Index 4 (15) das Spitzenelement dieses Arrays ist.

Beispiel

Hier ist der Code -

Live-Demonstration

const arr = [4, 6, 8, 12, 15, 11, 7, 4, 1];
const findPeak = (arr = []) => {
   if(arr.length < 3) {
      return -1
   }
   const helper = (low, high) => {
      if(low > high) {
         return -1
      }
      const middle = Math.floor((low + high) / 2)
      if(arr[middle] <= arr[middle + 1]) {
         return helper(middle + 1, high)
      }
      if(arr[middle] <= arr[middle - 1]) {
         return helper(low, middle - 1)
      }
      return middle
   }
   return helper(0, arr.length - 1)
};
console.log(findPeak(arr));
Nach dem Login kopieren

Ausgabe

4
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonFinden Sie den Peak einer Reihe zentraler Peaks in JavaScript. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:tutorialspoint.com
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!