题目大意:
就是现在初始 p = 1, 然后两个人轮流进行操作每次可以把p 乘上2~9中的任意一个正整数, 先把 p变成 >= n的人获胜
大致思路:
首先不难发现对于点k, k >= n的都是P点, 那么所有能到达P点的都是N点, 所以[n / 9, n - 1]是N点, 当然这里n / 9向上取整, 所以写代码的时候注意一下, 那么接下来一段只能到达N点的是P点, 所以[n / 9 / 2, n / 9 - 1]是P点, 一次类推即可, 一直推到1的位置看是N点还是P点就行了
代码如下:
Result : Accepted Memory : 1572 KB Time : 0 ms
/* * Author: Gatevin * Created Time: 2015/5/9 11:20:58 * File Name: Rin_Tohsaka.cpp */ #include<iostream> #include<sstream> #include<fstream> #include<vector> #include<list> #include<deque> #include<queue> #include<stack> #include<map> #include<set> #include<bitset> #include<algorithm> #include<cstdio> #include<cstdlib> #include<cstring> #include<cctype> #include<cmath> #include<ctime> #include<iomanip> using namespace std; const double eps(1e-8); typedef long long lint; #define foreach(e, x) for(__typeof(x.begin()) e = x.begin(); e != x.end(); ++e) #define SHOW_MEMORY(x) cout<<sizeof(x)/(1024*1024.)<<"MB"<<endl int n; int main() { while(scanf("%d", &n) != EOF) { bool np = 1;//n是N点 while(n != 1) { if(np)//接下来找到N点 { np = 0; n = n / 9 + (n % 9 != 0); } else { np = 1;//下一段是P点 n = n / 2 + (n & 1); } } printf("%s wins.\n", np ? "Ollie" : "Stan"); } return 0; }