关闭

博弈游戏(取石子)C++实现

标签: 游戏c++
135人阅读 评论(0) 收藏 举报
分类:

一、游戏思路:

欢迎来到“取石子”游戏世界,这是一个减法游戏。两名对手交替从某给定的总数减去一个数,每个对手只能减去1或者2, 谁第一个把总数减到零或者更小的数算谁赢。比如说:
(1)、我们从数字8开始,你先动手;
(2)、你从总数里减去2,还剩下6;
(3)、我也减去2,还剩下4;
(4)、你再减去2,还剩下2
(5)、我在减去2,等于零
(6)、我赢了
这是一个很简单的游戏,只需要考虑总数是的情况,不管你减去1还是2,我都可以在下一次把它减成零,从而获胜。简单的说,只要保证每次减后总数为3的倍数,那么最后一定会赢,不信的话,现在你就可以跟身边的这位测一测!!!

下面我将从编程角度来看问题,创建一个完整的游戏,并为计算机准备一个最佳策略,用户必须每一步都正确才能赢,一起来看看吧!!

二、游戏代码:

//#include"stdafx"
#include<iostream>
using namespace std;;
int main ()
{
    int total;
    int n;

    cout<<"欢迎来到取石子游戏"<<endl;
    cout<<"\n"<<endl;
    cout<<"请任意选择一个数开始游戏:"<<endl;
    cin>>total;
    while(true)
    {
        if(total%3==2)
        {
            total-=2;
            cout <<"我要减去2 ,现在的数为"<<total<<endl;
            cout<<"\n"<<endl;
        }
        else{  
                total-=1; 
                cout<<"我要减去1,现在的数字为:"<<total<<endl;
                cout<<"\n"<<endl;
             }
        if(total<=0)
             {
                 cout<<"我赢啦,你要加油哟"<<endl;
                 cout<<"\n"<<endl;
                    break;
                 }
        cout<<"该你说要减去的数啦,记得只能减1或者2唷:〉"<<endl;
        cin>>n;
        cout<<"\n"<<endl;
        while(n<1 ||n>2)
        {
            cout<<"每次只能减去1或者2, 你这人怎么能耍赖皮呢!!! "<<endl;
            cout<<"\n"<<endl;
            cout<<"快点重新说你要减去几!!!!"<<endl;
            cin>>n;
        }
        total-=n;
        cout<<"好啦,现在的数字为:"<<total<<endl;
        if(total<=0)
        {
            cout<<"好吧,算你赢"<<endl;
            break;
        }
}
}

三、执行结果

俗话说,什么样的性格写出什么样的代码,我这个大大咧咧宇宙无敌超级捣蛋鬼,写出的游戏自然十分俏皮了,你如果不喜欢游戏里面我的提示方式,可以添加你喜欢的语句,鄙人并不介意,那我就把草名写的程序的运行结果展示给大家,见下图:

这里写图片描述

四、简单分析:

该程序十分基本,只要涉猎C或者C++的人肯定不难理解,主要运用while( )循环和if()…..else 判断语句,另外,需要特别说明的是,在游戏中,如果对手不按规则来,也就是说,他一旦减的数字不是1或者2,需要作出提醒,要求重新输入。

五:特别说明:

本人学疏才浅,也是正走在编成路上的学者,不足之处还望海涵,另外,我会在写一些学术博客的同时,分享一些小游戏,使得我们的编程之路更加有趣生动!!
good night (:>

1
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

两人取石子游戏 组合数学-博弈问题

问题源于:编程之美。微策略笔试题。 微策略笔试题:桌子上有数值为Number的数字,2个玩家,每个玩家可以选择减去有 Number中连续1,2,,,,位构成的数值,桌子上换...
  • luckyjoy521
  • luckyjoy521
  • 2013-11-22 19:50
  • 7450

ACM-威佐夫博弈之取石子游戏——hdu1527

ACM 威佐夫博弈 取石子游戏 hdu1527
  • lx417147512
  • lx417147512
  • 2014-05-01 18:14
  • 2351

一排石头的游戏(取石头)C语言实现

问题描述: N块石头排成一行,每块石头有各自固定的位置。 两个玩家依次取石头,每个玩家可以取其中任意一块石头,或者相邻的两块石头,石头在游戏过程中不移位。 最后能将石头一次取光的玩家获胜。 ...
  • Zidane_2014
  • Zidane_2014
  • 2015-05-13 09:46
  • 1128

取石子游戏_博弈

  • 2014-11-10 17:41
  • 364KB
  • 下载

ACM-尼姆博弈之取(m堆)石子游戏——hdu2176

ACM 尼姆博弈 取(m堆)石子游戏 hdu2176 改变奇异态
  • lx417147512
  • lx417147512
  • 2014-05-02 15:40
  • 1925

HDU 1527 取石子游戏(威佐夫博弈)

Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Problem Descriptio...
  • miao_2cm
  • miao_2cm
  • 2016-07-27 21:50
  • 152

HDU1527:取石子游戏(威佐夫博弈)

Problem Description 有两堆石子,数量任意,可以不同。游戏开始由两个人轮流取石子。游戏规定,每次有两种不同的取法,一是可以在任意的一堆中取走任意多的石子;二是可以在两堆中同时取走相...
  • libin56842
  • libin56842
  • 2013-12-17 22:11
  • 2672

取石子游戏(hdu1527+威佐夫博弈)

Problem Description 有两堆石子,数量任意,可以不同。游戏开始由两个人轮流取石子。游戏规定,每次有两种不同的取法,一是可以在任意的一堆中取走任意多的石子;二是可以在两堆中同时取走相同...
  • u010579068
  • u010579068
  • 2015-08-05 23:21
  • 609

hdu 1527 取石子游戏 (威佐夫博弈模板)

取石子游戏Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Subm...
  • helloiamclh
  • helloiamclh
  • 2016-08-12 15:36
  • 181

【HDU1527】取石子游戏(威佐夫博弈)

题目:有两堆石子,数量任意,可以不同。游戏开始由两个人轮流取石子。游戏规定,每次有两种不同的取法,一是可以在任意的一堆中取走任意多的石子;二是可以在两堆中同时取走相同数量的石子。最后把石子全部取完者为...
  • can919
  • can919
  • 2017-02-10 19:36
  • 151
    个人资料
    • 访问:21374次
    • 积分:734
    • 等级:
    • 排名:千里之外
    • 原创:47篇
    • 转载:0篇
    • 译文:0篇
    • 评论:9条
    最新评论