Excel VBA, 59 46 Bayt
golfed
Anonim VBE Bir
dizi ( ) dizisini aralıktan girdi olarak alan ( ) ile sınırlandırılmış bir dizi ( ) dizisi [A1]
alan ve başlangıç listesindeki 1-temelli dizinlerini VBE hemen penceresine dönüştüren acil pencere işlevi
For Each n In Split([A1]):i=i+1:?n Mod i;:Next
Giriş çıkış:
[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
Eski Sub
rutin sürüm
Girdiyi bir dizi olarak alan ve VBE hemen penceresine outoutlar.
Sub m(n)
For Each a In n
i=i+1
Debug.?a Mod i;
Next
End Sub
Giriş / Çıkış:
m Array(10,9,8,7,6,5,4,3,2,1)
0 1 2 3 1 5 4 3 2 1
Ungolfed
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
Giriş çıkış:
Call modIndex(10,9,8,7,6,5,4,3,2,1)
0 1 2 3 1 5 4 3 2 1