F - Infinite Sequence Editorial /

Time Limit: 2 sec / Memory Limit: 256 MB

配点 : 10001000

問題文

{1,...,n{1, ... ,n}} からなる無限長の列 a1,a2,...a_1, a_2, ... のうち、 次の条件を満たしているものは何通りあるでしょうか?

  • nn 項から先はすべて同じ数である。つまり、ni,jn \leq i,j ならば ai=aja_i = a_j を満たす。
  • どの正の整数 ii に対しても、第 ii 項の直後に並ぶ aia_i 個の項はすべて同じ数である。つまり、 i<j<ki+aii < j < k\leq i+a_i ならば aj=aka_j = a_k を満たす。

答えを 109+710^9+7 で割ったあまりを求めてください。

制約

  • 1n1061 \leq n \leq 10^6
  • nn は整数

入力

入力は以下の形式で標準入力から与えられる。

nn

出力

条件を満たす数列の数を 109+710^9+7 で割ったあまりを出力せよ。


入力例 1Copy

Copy
2

出力例 1Copy

Copy
4

以下の 44 通りがあります。

  • 1,1,1,...1, 1, 1, ...
  • 1,2,2,...1, 2, 2, ...
  • 2,1,1,...2, 1, 1, ...
  • 2,2,2,...2, 2, 2, ...

入力例 2Copy

Copy
654321

出力例 2Copy

Copy
968545283

Score : 10001000 points

Problem Statement

How many infinite sequences a1,a2,...a_1, a_2, ... consisting of {1,...,n{1, ... ,n}} satisfy the following conditions?

  • The nn-th and subsequent elements are all equal. That is, if ni,jn \leq i,j, ai=aja_i = a_j.
  • For every integer ii, the aia_i elements immediately following the ii-th element are all equal. That is, if i<j<ki+aii < j < k\leq i+a_i, aj=aka_j = a_k.

Find the count modulo 109+710^9+7.

Constraints

  • 1n1061 \leq n \leq 10^6

Input

Input is given from Standard Input in the following format:

nn

Output

Print how many sequences satisfy the conditions, modulo 109+710^9+7.


Sample Input 1Copy

Copy
2

Sample Output 1Copy

Copy
4

The four sequences that satisfy the conditions are:

  • 1,1,1,...1, 1, 1, ...
  • 1,2,2,...1, 2, 2, ...
  • 2,1,1,...2, 1, 1, ...
  • 2,2,2,...2, 2, 2, ...

Sample Input 2Copy

Copy
654321

Sample Output 2Copy

Copy
968545283


2025-04-16 (Wed)
05:02:28 +00:00