Submission #1591975


Source Code Expand

#include<bits/stdc++.h>

#define MOD ((int)(1e9+7))

using namespace std;

typedef long long int Int;

Int pnum[1000];

bool IsPrime(Int n)
{
    Int num = sqrt(1.0*n);
    if(n == 2)
    {
	return true;
    }

    for(int i = 2;i <= num;i += 2)
    {
	if(n % i == 0)
	    return false;
    }

    return true;
}

Int Solve(Int n)
{
    Int count = 1;

    for(int i = 0;i < 1000;i++)
	pnum[i] = 1;

    for(int i = 2;i <= n;i++)
    {
	Int temp = i;
	for(int j = 2;j <= temp;) {
	    if(temp % j == 0 && IsPrime(j))
	    {
		pnum[j]++;
		temp /= j;
	    } else {
		j++;
	    }
	}
    }

    for(int i = 0;i < 1000;i++)
    {
	count = (count*pnum[i])%MOD;
    }

    return count;
}

int main(void)
{
    Int n;
    cin>>n;

    cout<<Solve(n)<<endl;

    return 0;
}

Submission Info

Submission Time
Task C - Factors of Factorial
User gktni
Language C++14 (GCC 5.4.1)
Score 300
Code Size 833 Byte
Status AC
Exec Time 3 ms
Memory 256 KB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 300 / 300
Status
AC × 3
AC × 10
Set Name Test Cases
Sample sample_01.txt, sample_02.txt, sample_03.txt
All sample_01.txt, sample_02.txt, sample_03.txt, subtask_1_certain_01.txt, subtask_1_certain_02.txt, subtask_1_certain_03.txt, subtask_1_certain_04.txt, subtask_1_rand_01.txt, subtask_1_rand_02.txt, subtask_1_rand_03.txt
Case Name Status Exec Time Memory
sample_01.txt AC 1 ms 256 KB
sample_02.txt AC 1 ms 256 KB
sample_03.txt AC 3 ms 256 KB
subtask_1_certain_01.txt AC 1 ms 256 KB
subtask_1_certain_02.txt AC 1 ms 256 KB
subtask_1_certain_03.txt AC 3 ms 256 KB
subtask_1_certain_04.txt AC 3 ms 256 KB
subtask_1_rand_01.txt AC 2 ms 256 KB
subtask_1_rand_02.txt AC 2 ms 256 KB
subtask_1_rand_03.txt AC 1 ms 256 KB