uva 1567 - A simple stone game(K倍动态减法游戏)
2024-09-30 02:34:24
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;
}
最新文章
- 实时数据显示--SignalR实例演示
- Effective C++ -----条款23:宁以non-member、non-friend替换member函数
- ToolStrip添加自定义的DateTimePicker
- 【转】Swift开源项目精选
- Ado.Net要知道的东西
- 用C语言制作小型商品信息管理系统过程中的问题
- JavaScript常用全局属性与方法
- UE4 径向模糊radiu blur
- snmp简单测试
- 另类AOP设计
- Pool:小对象缓存or复用
- vue中watch的详细用法
- 33. 完全卸载oracle11g步骤
- sqlserver 自动创建作业执行备份数据库
- BZOJ 1066 蜥蜴 最大流
- cxGrid使用汇总
- 重点:怎样正确的使用QThread类(注:包括推荐使用QThread线程的新方法QObject::moveToThread)
- 如果修改GeneXus Android的一些源码文件(FlexibleClient)
- 自定义View总结
- odoo 使用源码安装时的注意
热门文章
- HDU 2829 斜率优化DP Lawrence
- Tomcat下部署PHP
- appium之android_uiautomator定位进阶版
- World Finals 2017
- 【bzoj4889】[Tjoi2017]不勤劳的图书管理员 树状数组+分块+二分
- 【Luogu】P3865ST表模板(ST表)
- SPOJ GSS4 Can you answer these queries IV ——树状数组 并查集
- 【2018.10.15】noip模拟赛Day1
- 【2018.9.20】JOI 2017 Final T2「準急電車 / Semiexpress」
- 窗口(codevs 4373)