Ви, напевно, всі знаєте послідовність рівня:
fibonacci(n)=fibonacci(n-1)+fibonacci(n-2)
fibonacci(0)=0
fibonacci(1)=1
Ваше завдання таке просте, як це могло бути:
- Дано
N
обчислення цілих чиселfibonacci(n)
але ось поворот:
- Також роби негатив
N
Зачекайте. Що?
fibonacci(1)=fibonacci(0)+fibonacci(-1)
так
fibonacci(-1)=1
і
fibonacci(-2)=fibonacci(0)-fibonacci(1)=-1
і так далі...
- Це кодовий гольф, тому найкоротша програма виграти в байтах.
- Ви можете подати функцію або повну програму
- N знаходиться в [-100,100]
Тестовий зразок у форматі CSV:
-9;-8;-7;-6;-5;-4;-3;-2;-1;0;1;2;3;4;5;6;7;8
34;-21;13;-8;5;-3;2;-1;1;0;1;1;2;3;5;8;13;21
Підказка:
n <0 і n & 1 == 0:
fibonacci(n)=fibonacci(abs(n))*-1