Rubrik: Variablen/Strings · Array/ArrayList | VB-Versionen: VB2005, VB2008. VB2010 | 26.04.11 |
Funktion zum Ermitteln der n kleinsten oder größten Werte eines Array Die Funktion gibt in einem Feld die Indizes der n kleinsten oder größten Werte eines Array zurück. | ||
Autor: Dietrich Herrmann | Bewertung: | Views: 10.285 |
ohne Homepage | System: Win2k, WinXP, Win7, Win8, Win10, Win11 | kein Beispielprojekt |
In einem Projekt benötigte ich diese kleine Hilfsfunktion. Durch sie werden die Indizes entweder der n kleinsten oder der n größten Werte eines Arrays bereit gestellt, um über sie dann gegebenenfalls auf die entsprechenden Werte zugreifen zu können. Der Trick dabei ist, dass das vom Originalfeld abgeleitete temporäre Feld einfach sortiert wird. Dann sind die ersten n Werte die kleinsten und die letzten n Werte die größten.
''' <summary> ''' Funktion zum Ermitteln der n kleinsten oder größten Werte eines Array ''' </summary> ''' <param name="theArray">das Feld</param> ''' <param name="n">Anzahl der Werte</param> ''' <param name="MaxMinFlag">Maximal(True)- oder Minimal(False)-Werte ermitteln</param> ''' <param name="sortFlag">Ergebnis-Indizes sortieren ja|nein</param> ''' <returns>Feld der Indizes</returns> Public Function GetNumberOfMaxMin(ByVal theArray As Array, ByVal n As Short, _ Optional ByVal MaxMinFlag As Boolean = True, _ Optional ByVal sortFlag As Boolean = False) As Array If theArray.Length - n <= 0 Then Return Nothing Dim l As Short = theArray.Length Dim ergFeld(n - 1) As Short ' Ergebnisfeld für die Indizes Dim tempFeld As Array = Array.CreateInstance(theArray.GetType, l) ' temporäres Feld tempFeld = theArray.Clone tempFeld.Sort(tempFeld) For i As Short = 0 To n - 1 If MaxMinFlag Then ' die größten Werte ergFeld(i) = theArray.IndexOf(theArray, tempFeld(l - n + i)) Else ' die kleinsten Werte ergFeld(i) = theArray.IndexOf(theArray, tempFeld(i)) End If Next If sortFlag Then ergFeld.Sort(ergFeld) Return ergFeld End Function