... tradurre l'algoritmo di Knuth in Gambas?
Eccolo di seguito anche inserito in un esempio pratico:
Private Const RAND_MAX As Integer = 2147483647
Public Sub Main()
Dim ii As Integer[] = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10,
11, 12, 13, 14, 15, 16, 17, 18, 19, 20]
Dim i As Integer
Knuth_perm(ii.Count, ii) ' Ritorno dei dati per "Indirizzo" '
For Each i In ii
Print i
Next
End
Private Function Knuth_perm(size As Long, _pi As Integer[]) ' Ritorno dei dati per "Indirizzo" '
Dim i, p As Long
Dim t As Integer
For i = size To 2 Step - 1
p = CInt(Rnd(0, RAND_MAX)) Mod i
t = _pi[p]
_pi[p] = _pi[i - 1]
_pi[i - 1] = t
Next
End
Per essere più filologicamente aderenti al codice, scritto in C, si sarebbe dovuto passare alla Funzione "
Knuth_perm( ) " l'indirizzo di memoria della variabile vettoriale e quindi utilizzare lì una variabile di tipo "Puntatore", gestendola in
lettura con le specifiche funzioni native di dereferenziazione ed in
scrittura mediante i
Memory Stream.