option=com_onlinejudge&Itemid=8&page=show_problem&problem=4342">题目链接:uva 1567 - A simple stone game

题目大意:给定K和N。表示一堆石子有N个。先手第一次能够取1~N-1个石子,取到最后一个石子的人胜利,单词每次操作时,取的石子数不能超过对手上一次取的石子数m的K倍。

问先手能否够必胜。能够输出最小的首次操作。

解题思路:这题想了一天,又是打表找规律。又是推公式的,楞是做不出来,后来在网上找到了一篇题解,将的非常清楚,解题宝典

/*******************
* K倍动态减法游戏
* 參考:http://www.cnblogs.com/jianglangcaijin/archive/2012/12/19/2825539.html
*******************/ #include <cstdio>
#include <cstring>
#include <algorithm> using namespace std;
const int maxn = 1e6+5; int N, K, a[maxn], b[maxn]; int main () {
int cas;
scanf("%d", &cas);
for (int i = 1; i <= cas; i++) {
scanf("%d%d", &N, &K);
int p = 0, q = 0;
a[0] = b[0] = 0;
while (a[p] < N) {
a[p+1] = b[p] + 1;
p++; while (a[q + 1] * K < a[p])
q++;
b[p] = b[q] + a[p];
} printf("Case %d: ", i);
if (N == a[p])
printf("lose\n");
else {
int ans;
while (N) {
if (N >= a[p]) {
N -= a[p];
ans = a[p];
}
p--;
}
printf("%d\n", ans);
}
}
return 0;
}

最新文章

  1. 实时数据显示--SignalR实例演示
  2. Effective C++ -----条款23:宁以non-member、non-friend替换member函数
  3. ToolStrip添加自定义的DateTimePicker
  4. 【转】Swift开源项目精选
  5. Ado.Net要知道的东西
  6. 用C语言制作小型商品信息管理系统过程中的问题
  7. JavaScript常用全局属性与方法
  8. UE4 径向模糊radiu blur
  9. snmp简单测试
  10. 另类AOP设计
  11. Pool:小对象缓存or复用
  12. vue中watch的详细用法
  13. 33. 完全卸载oracle11g步骤
  14. sqlserver 自动创建作业执行备份数据库
  15. BZOJ 1066 蜥蜴 最大流
  16. cxGrid使用汇总
  17. 重点:怎样正确的使用QThread类(注:包括推荐使用QThread线程的新方法QObject::moveToThread)
  18. 如果修改GeneXus Android的一些源码文件(FlexibleClient)
  19. 自定义View总结
  20. odoo 使用源码安装时的注意

热门文章

  1. HDU 2829 斜率优化DP Lawrence
  2. Tomcat下部署PHP
  3. appium之android_uiautomator定位进阶版
  4. World Finals 2017
  5. 【bzoj4889】[Tjoi2017]不勤劳的图书管理员 树状数组+分块+二分
  6. 【Luogu】P3865ST表模板(ST表)
  7. SPOJ GSS4 Can you answer these queries IV ——树状数组 并查集
  8. 【2018.10.15】noip模拟赛Day1
  9. 【2018.9.20】JOI 2017 Final T2「準急電車 / Semiexpress」
  10. 窗口(codevs 4373)