← Home
write a go solution for Description:
Let's define a function f(p) on a permutation p as follows. Let g_i be the greatest common divisor (GCD) of elements p_1, p_2, ..., p_i (in other words, it is the GCD of the prefix of length i). Then f(p) is the number of distinct elements among g_1, g_2, ..., g_n.

Let f_max(n) be the maximum value of f(p) among all permutations p of integers 1, 2, ..., n.

Given an integers n, count the number of permutations p of integers 1, 2, ..., n, such that f(p) is equal to f_max(n). Since the answer may be large, print the remainder of its division by 1000,000,007=10^9+7.

Input Format:
The only line contains the integer n (2<=n<=10^6) — the length of the permutations.

Output Format:
The only line should contain your answer modulo 10^9+7.

Note:
Consider the second example: these are the permutations of length 3:

- [1,2,3], f(p)=1.
- [1,3,2], f(p)=1.
- [2,1,3], f(p)=2.
- [2,3,1], f(p)=2.
- [3,1,2], f(p)=2.
- [3,2,1], f(p)=2.

The maximum value f_max(3)=2, and there are 4 permutations p such that f(p)=2.. Output only the code with no comments, explanation, or additional text.