Excel VBA, 59 46 bajtów
Grał w golfa
Anonimowa funkcja VBE Natychmiastowa funkcja okna, która pobiera
ciąg tablicy rozdzielany spacją jako dane wejściowe z zakresu [A1]
i wypisuje moduł liczb ich indeks 1 na liście początkowej do bezpośredniego okna VBE
For Each n In Split([A1]):i=i+1:?n Mod i;:Next
Wejście wyjście:
[A1]="10 9 8 7 6 5 4 3 2 1" ''# or manually set the value
For Each n In Split([A1]):i=i+1:?n Mod i;:Next
0 1 2 3 1 5 4 3 2 1
Stara Sub
rutynowa wersja
Podprogram, który pobiera dane wejściowe jako przekazaną tablicę i wychodzi do bezpośredniego okna VBE.
Sub m(n)
For Each a In n
i=i+1
Debug.?a Mod i;
Next
End Sub
Wejście / Ouput:
m Array(10,9,8,7,6,5,4,3,2,1)
0 1 2 3 1 5 4 3 2 1
Nie golfił
Option Private Module
Option Compare Binary
Option Explicit
Option Base 0 ''# apparently Option Base 1 does not work with ParamArrays
Public Sub modIndex(ParamArray n() As Variant)
Dim index As Integer
For index = LBound(n) To UBound(n)
Debug.Print n(index) Mod (index + 1);
Next index
End Sub
Wejście wyjście:
Call modIndex(10,9,8,7,6,5,4,3,2,1)
0 1 2 3 1 5 4 3 2 1