Avatar billede galthen Nybegynder
26. august 2003 - 08:44 Der er 8 kommentarer og
1 løsning

Sortering af Array

Jeg har brug for en stykke kode som kan sortere et array så f.eks. den største værdi kommer til at ligge på plads 0 osv..

Nogle forslag?
Avatar billede adam_christensen Nybegynder
26. august 2003 - 08:47 #1
Function ArraySort(aSort, intAsc)
    Dim intTempStore
    Dim i, j
    For i = 0 To UBound(aSort) - 1
      For j = i To UBound(aSort)
          'Sort Ascending
          If intAsc = 1 Then
            If aSort(i) > aSort(j) Then
                intTempStore = aSort(i)
                aSort(i) = aSort(j)
                aSort(j) = intTempStore
            End if 'i > j
          'Sort Descending
          Else
            if aSort(i) < aSort(j) Then
                intTempStore = aSort(i)
                aSort(i) = aSort(j)
                aSort(j) = intTempStore
            End if 'i < j
          End if 'intAsc = 1
      Next 'j
    Next 'i
    ArraySort = aSort
End Function
Avatar billede galthen Nybegynder
26. august 2003 - 08:53 #2
Når jeg kalder funktionen..
Hvilke parametre skal så ind på de to pladser?
ArraySort(aSort, intAsc)
Avatar billede adam_christensen Nybegynder
26. august 2003 - 08:54 #3
aSort er det array du gerne vil sortere.
intAsc sættes til 1 for at sortere stigende. 0 for at sortere faldende.
Avatar billede galthen Nybegynder
26. august 2003 - 08:55 #4
Hhhmm..
Jeg kalder den sådan.. Men det virker ikke
ArraySort(MyArray,0)
Avatar billede galthen Nybegynder
26. august 2003 - 08:57 #5
Her er hele min test:

<%

Function ArraySort(aSort, intAsc)
    Dim intTempStore
    Dim i, j
    For i = 0 To UBound(aSort) - 1
      For j = i To UBound(aSort)
          'Sort Ascending
          If intAsc = 1 Then
            If aSort(i) > aSort(j) Then
                intTempStore = aSort(i)
                aSort(i) = aSort(j)
                aSort(j) = intTempStore
            End if 'i > j
          'Sort Descending
          Else
            if aSort(i) < aSort(j) Then
                intTempStore = aSort(i)
                aSort(i) = aSort(j)
                aSort(j) = intTempStore
            End if 'i < j
          End if 'intAsc = 1
      Next 'j
    Next 'i
    ArraySort = aSort
End Function

Dim MyArray (5)
MyArray(0)=1
MyArray(1)=2
MyArray(2)=3
MyArray(3)=4
MyArray(4)=5
Response.write MyArray(0) &"<br>"
ArraySort(MyArray(0),1)
Response.write MyArray(0)

%>
Avatar billede galthen Nybegynder
26. august 2003 - 08:58 #6
Anden siste skulle have set sådan ud:
ArraySort(MyArray,1)
Avatar billede adam_christensen Nybegynder
26. august 2003 - 09:02 #7
Du skal putte resultatet af sorteringen over i et nyt array:

SorteretArray = ArraySort(MyArray(0),1)

Dette VB Script illustrerer brugen:

Function ArraySort(aSort, intAsc)
    Dim intTempStore
    Dim i, j
    For i = 0 To UBound(aSort) - 1
      For j = i To UBound(aSort)
          'Sort Ascending
          If intAsc = 1 Then
            If aSort(i) > aSort(j) Then
                intTempStore = aSort(i)
                aSort(i) = aSort(j)
                aSort(j) = intTempStore
            End if 'i > j
          'Sort Descending
          Else
            if aSort(i) < aSort(j) Then
                intTempStore = aSort(i)
                aSort(i) = aSort(j)
                aSort(j) = intTempStore
            End if 'i < j
          End if 'intAsc = 1
      Next 'j
    Next 'i
    ArraySort = aSort
End Function

Dim aRaw(10)

For i = 0 to 10
  aRaw(i) = Round(Rnd*100)
Next

' Sortér stigende
aSorted = ArraySort(aRaw, 1)

strMsg = "Stigende:" & vbCRLF
For i = 0 to UBound(aSorted)
  strMsg = strMsg & aSorted(i) & vbCRLF
Next
MsgBox strMsg

' Sortér faldende
aSorted = ArraySort(aRaw, 0)
strMsg = "Faldende:" & vbCRLF
For i = 0 to UBound(aSorted)
  strMsg = strMsg & aSorted(i) & vbCRLF
Next
MsgBox strMsg
Avatar billede adam_christensen Nybegynder
26. august 2003 - 09:03 #8
Hov, overså lige (0). Syntaxen er

SorteretArray = ArraySort(MyArray,1)
Avatar billede galthen Nybegynder
26. august 2003 - 09:05 #9
Super...
Den havde jeg lige overset.. Tak for hjælpen :o)
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Kurser inden for grundlæggende programmering

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester