Description
Return the number of permutations of 1 to n so that prime numbers are at prime indices (1-indexed.)
(Recall that an integer is prime if and only if it is greater than 1, and cannot be written as a product of two positive integers both smaller than it.)
Since the answer may be large, return the answer modulo 10^9 + 7.
Example 1:
Input: n = 5
Output: 12
Explanation: For example [1,2,5,4,3] is a valid permutation, but [5,2,3,4,1] is not because the prime number 5 is at index 1.
Example 2:
Input: n = 100
Output: 682289015
Constraints:
1 <= n <= 100
Solution
- First get the number of prime numbers in n numbers
- Then get the number of non-prime numbers = n - the number of prime numbers
- The answer is obtained by multiplying the number of permutations of prime numbers by the number of permutations of non-primes.
1 | # O(n) time | O(n) space |
How to find prime numbers in a range
1 | num = []; |
Factorial
For Loop
1 | ans = 1 |
Reduce Function
1 | from functools import reduce |
Recursion
1 | def factorial(n): |
[^1]: 1175. Prime Arrangements
[^2]: Using else conditional statement with for loop in python