题目描述
佳佳对数学,尤其对数列十分感兴趣。在研究完 Fibonacci 数列后,他创造出许多稀奇古怪的数列。例如用S(n)表示Fibonacci前n项和modm的值,即 S(n)=(F1+F2+...+Fn)modm,其中F1=F2=1,Fi=Fi−1+Fi−2。可这对佳佳来说还是小菜一碟。
终于,她找到了一个自己解决不了的问题。用T(n)=(F1+2F2+3F3+...+nFn)modm表示Fibonacci 数列前n项变形后的和modm的值。
现在佳佳告诉你了一个n和m,请求出T(n) 的值。
输入格式
输入数据包括一行,两个用空格隔开的整数n,m。
输出格式
仅一行,T(n) 的值。
样例
输入样例
5 5
输出样例
1
T(5)=(1+2×1+3×2+4×3+5×5)mod5=1
数据范围与提示
对于30%的数据,1≤n≤1000;
对于60%的数据,1≤m≤1000;
对于100%的数据,1≤n,m≤231−1。