Eine Erklärung der Idee, das größte Subarray in PHP zu implementieren

不言
Freigeben: 2023-04-04 07:18:02
Original
1516 Leute haben es durchsucht

Was dieser Artikel Ihnen bringt, ist eine Erklärung der Idee, das größte Subarray in PHP zu implementieren. Ich hoffe, dass er für Sie hilfreich ist.

key
buy
sell
for i=0;i<n;i++
    for j=i+1;j<n;j++
        p=key=arr[j]-arr[i]
        if !key key=p
        if key<p buy=i sell=j
Nach dem Login kopieren

Problemvariante: Das Subarray mit der größten kontinuierlichen Summe von Elementen in Array A ist nur dann sinnvoll, wenn die Elemente negative Zahlen haben
Die Lösungsidee der Divide-and-Conquer-Strategie:
1 . Finden Sie die zentrale Position mid,A[low..mid],A[mid+1..high]
2.A[low,high] liegt vollständig im Unterarray A[low..mid ] low<=i<=j< ;=mid
3 Vollständig gelegen bei A[mid+1..high] mid4. =mid5. Finden Sie die maximale Summe der linken Hälfte (suchen Sie von der Mitte nach links), finden Sie die maximale Summe der rechten Hälfte (suchen Sie von der Mitte nach rechts)

leftSum left
for i=mid;i>=low;i--
    sum=sum+A[i]
    if sum>leftSum
        leftSum=sum
        left=i
rightSum right
for j=mid+1;j<=high;j++
    sum+=A[j]
    if sum > rightSum
        rightSum=sum
        right=i
6.递归调用
    mid=(low+high)/2
    find(A,low,mid)
    find(A,mid+1,high)
    findCross(A,low,mid,high)
Nach dem Login kopieren

Verwandte Empfehlungen:

Erklärung von 2 Lösungen für das Problem, die maximale Summe aufeinanderfolgender Subarrays in PHP zu finden

Die Methode zum Lösen des längsten gemeinsamen Teilstrings in PHP

Das obige ist der detaillierte Inhalt vonEine Erklärung der Idee, das größte Subarray in PHP zu implementieren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
php
Quelle:php.cn
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