开发者

Searching for a positional function in recursive formula

开发者 https://www.devze.com 2023-03-18 01:15 出处:网络
First do note that my english in not the best here. If anyone is interested in helping me in solving this problem and want me detail something better, do not esitate in asking more details.

First do note that my english in not the best here. If anyone is interested in helping me in solving this problem and want me detail something better, do not esitate in asking more details.

A specific solution in any tagged given language is much appreciated. Even if more general solution in term of formula is the target of this question.

Thanks


Let define Sequence Rule SR, a fixed sequence of integer numbers:

SR = (a, b, c, d, ..)


Example

SR = (1, 2, 3, 5)

Let define Shifting Sequence rule SS the sequence obtain开发者_StackOverflow中文版ed by SR as:

SS = (a-0,b-a,c-b,d-c,..-d)


Example

(1-0, 2-1, 3-2, 5-3) = (1, 1, 1, 2)

The shifting sequence rule SS should compute to an output sequence OS according to the following recursive formula:

OS(n) = 0, n=0

OS(n) = OS(n-1) + SS(i), n>0

where i is the position of n in the current subgroup SS.


Example

OS(n) = (1, 2, 3, 5, 6, 7, 8, 10, 11, 12, 13, 15..)

where n=(1,2,3,4,5,6,7,8,9,10,11,12,..).

OS(0) = 0
OS(1)  = OS(0)  + SS(1) = 0 + 1  = 1
OS(2)  = OS(1)  + SS(2) = 1 + 1  = 2
OS(3)  = OS(2)  + SS(3) = 2 + 1  = 3
OS(4)  = OS(3)  + SS(4) = 3 + 2  = 5
OS(5)  = OS(4)  + SS(1) = 5 + 1  = 6
OS(6)  = OS(5)  + SS(2) = 6 + 1  = 7
OS(7)  = OS(6)  + SS(3) = 7 + 1  = 8
OS(8)  = OS(7)  + SS(4) = 8 + 2  = 10
OS(9)  = OS(8)  + SS(1) = 10 + 1 = 11
OS(10) = OS(9)  + SS(2) = 11 + 1 = 12
OS(11) = OS(10) + SS(3) = 12 + 1 = 13
OS(12) = OS(11) + SS(4) = 13 + 2 = 15

What actually I'm missing (not able to get) is the current position of n in the related shifting group given n only, such that:

pos(n)=i -> S(pos(n)) = S(i)

so finally I can write

OS(0) = 0

OS(n) = OS(n-1) + SS(pos(n))


What I've been able to get till now is a formula for the current index of the shifting group. I suspect it can help me in determining the wanted positional formula pos(n), but don't know how :((

The group index can be expressed as:

G(n)=ceiling(n/D(SS))

Where D(SS) is the dimension of SS, that is the number of elements in in the sequence rule.


Example

For example the $n$ sequence ranges 1 to 12. The number of shifting groups (1,1,1,2) of dimension 4 that makes a 1->1 mapping to OS(n) are 3 = 12/4.

The grouping index for n=9 can be computed as:

 G(9) = ceiling(n/D(SR)) = ceiling(9/4) = 3

FINAL ANSWER


The usage of the % operator is what I was missing. The final recursive formula is:

OS(n) = 0, n=0

OS(n) = OS(n-1) + SS((n + D(SR)-1) % D(SR) + 1), n>0

Or using a pure mathematical formula (and the definition of group index above):

OS(n) = 0, n=0

OS(n) = OS(n-1) + SS((n + D(SR)-1 - (D(SR) * G(n)) + 1), n>0


THANKS @GARETH


The question is quite hard to understand, but I think that you are looking for the modulus operation.

The sequence SS has 4 elements, so pos(n) is n modulo 4.

This operation can be computed in many programming languages—including C# and Ruby—by the % operator, and in Haskell by the mod function.


If you need the modulus to be in the range 1 to 4 rather than 0 to 3, use this expression:

(n + 3) % 4 + 1
0

精彩评论

暂无评论...
验证码 换一张
取 消