题目来源:http://acm.nyist.net/JudgeOnline/problem.php?pid=91
贪心
#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
int main()
{
int arr[10] = {1, 2, 6, 24, 120, 720, 5040, 40320, 362880, 3628800};
int T, n, t, i;
bool flag;
scanf("%d", &T);
while(T--)
{
flag = false, t = 0;
scanf("%d", &n);
for(i = 9; i >= 0; --i)
{
if(t+arr[i] <= n)
t += arr[i];
if(t == n)
{
flag = true;
break ;
}
}
if(flag)
printf("Yes\n");
else
printf("No\n");
}
return 0;
}