IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> (HDU - 1525)Euclid‘s Game(博弈) -> 正文阅读

[C++知识库](HDU - 1525)Euclid‘s Game(博弈)

题目链接:Euclid's Game - HDU 1525 - Virtual Judge (ppsucxtt.cn)

题目大意:有两个玩家,Stan 和 Ollie, 在玩游戏。初始有两个自然数。Stan是先手,每次把大的数字减去小的数字的任意倍数,但是不能使数字变成负数。然后Ollie进行同样的操作,直到有一个玩家使一个数字变为零。

容易知道,对于刚开始给定的m和n(不妨假设m>=n),若m是n的整数倍,显然先手可以通过一步操作直接胜出。

当m>2*n时,先手也必胜,下面给出证明:

不妨设m=k*n+r,m>2*n等价于k>=2,对于先手可以直接进行(m,n)-->( r , n ) 操作,当( r , n ),为一种必败态时,先手直接获胜,若( r , n ),为一种必胜态时,先手可以进行

(m,n)-->( r + n , n )操作,这样后手只能进行?( r + n , n )?-->( r ?, n )操作,这样先手就进入了必胜态,也可以取得胜利,所以只要是m>2*n时,先手必胜。

现在我们确定了两种必胜态,一种是m>2*n,另一种是m%n==0,下面我们来讨论m<2*n的情况

若m<2*n,则先手只能进行(m,n)-->( m-n, n ),若n<2*(m-n)则重复进行上述操作,倘若在运行过程中出现两个数的较大数大于较小数的2倍或者可以被较小数整除时,就可以判断胜负了,也就是判断必胜态首先发生在谁身上。

下面上代码:

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
#include<queue>
using namespace std;
int main()
{
	int m,n;
	while(1)
	{
		
		scanf("%d%d",&m,&n);
		if(m==0&&n==0) break;
		if(m<n) swap(m,n);
		if(m>2*n||m%n==0)
			puts("Stan wins");
		else
		{
			int cnt=1;
			while(m&&n)
			{
				if(m<n) swap(m,n);
				if(m>2*n||m%n==0)
				{
					if(cnt&1) puts("Stan wins");//判断是谁优先进入必胜态 
					else puts("Ollie wins");
					break;
				}
				m-=n;
				cnt++;
			}
		}
	}
	return 0;
}

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-10-03 16:54:12  更:2021-10-03 16:56:03 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 1:13:14-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码