简单取石子游戏~博弈

2024-09-08 00:18
文章标签 简单 游戏 博弈 石子

本文主要是介绍简单取石子游戏~博弈,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

很坑爹的小游戏,至于怎么坑爹,嘎嘎~自己研究去吧~!
#include<stdio.h>
#include<windows.h>
#include<iostream>
#include<string.h>
#include<time.h>
using namespace std;
void Loc(int x,int y);/*定位光标*/
void Welcome(); /*创建欢迎界面*/
void BuildMap();/*创建界面*/
void GetNumber();/*获得测试的值n,m,s*/
void Choice();   /*玩家选择是否先手*/
void GameStart();/*开始游戏!*/
void ShowScore();
void End();
int n1,n2,m,s,r,n;/*n1为玩家先手的石子个数,n2为电脑先手的石子个数*/
int YesNo;/*1为玩家先手,2为电脑先手*/
void Loc(int x,int y)
{COORD pos={x,y};HANDLE hout=GetStdHandle(STD_OUTPUT_HANDLE);SetConsoleCursorPosition(hout,pos);
}
void Welcome()
{char YesOrNo[10];Loc(13,3);printf("如果你已经熟悉游戏规则请输入'Y'跳过规则介绍,否则输入'N':");scanf("%s",&YesOrNo);if(YesOrNo[0]=='Y') return;Loc(13,5);printf("欢迎测试<博弈的智慧>~下面简述游戏规则:\n");Sleep(1000);/*延迟*/Loc(13,7);Sleep(2000);/*延迟*/printf("程序给出n个石子以及每次最多能拿走的石子个数m\n");Loc(13,9);Sleep(3000);/*延迟*/printf("玩家可以选择先手或者后手,每次最少拿走1个\n");Loc(13,11);Sleep(3000);/*延迟*/printf("谁拿最后一个石子就获得比赛的胜利!~");Loc(13,13);Sleep(2000);printf("如果赢得了比赛之后会有神秘的奖励哦~");Sleep(3000);system("cls");
}
void GetNumber()
{srand((unsigned int)time(NULL));m=rand()%8+3;/*获得一个在3~10的随机数*/r=rand()%5+2;/*生成一个2~6的随机数*/s=m-2;       /*s在1~8内*/n1=(m+1)*r;  /*玩家先手*/n2=(m+1)*r+s;/*电脑先手*/
}
void Choice()
{char YesOrNo[10];Loc(13,7);printf("你是否选择先手取石子?(输入Y/N):");scanf("%s",YesOrNo);if(YesOrNo[0]=='Y') YesNo=1;/*如果选择了先手*/else YesNo=0;/*选择了后手*/Loc(15,10);if(YesNo==1)printf("你选择了先手取石子!");elseprintf("你选择了后手取石子!");Sleep(2000);system("cls");
}
void BuildMap()
{for(int i=0;i<=50;i+=2){Loc(i,0);printf("■");Loc(i,50);printf("■");}for(int i=0;i<=50;i++){Loc(0,i);printf("■");Loc(50,i);printf("■");}for(int i=52;i<=70;i+=2){Loc(i,0);printf("■");Loc(i,10);printf("■");}for(int i=0;i<=10;i++){Loc(52,i);printf("■");Loc(70,i);printf("■");}for(int i=52;i<=70;i+=2){Loc(i,12);printf("■");Loc(i,20);printf("■");}for(int i=12;i<=20;i++){Loc(52,i);printf("■");Loc(70,i);printf("■");}Loc(55,14);printf("<博弈的智慧>");Loc(55,16);printf("作者:Hsk");Loc(55,19);printf("感谢您的使用!");
}
void ShowScore()/*状态栏*/
{Loc(54,2);printf("剩余石子个数:%d",n);Loc(54,4);printf("最多可拿个数:%d",m);
}
void GameStart()
{int y1=2,x;/*定位左/右画面的移动*/if(YesNo==1){n=n1;}elsen=n2;ShowScore();Sleep(4000);if(YesNo==0)/*如果电脑先取石子*/{n=n-s;ShowScore();Loc(2,y1);printf("电脑取走了%d个石子,还剩余%d个",s,n);y1+=2;}while(n>0){Loc(54,6);printf("输入取石数:");scanf("%d",&x);/*玩家取走了x个*/if(x>m||x<1) /*如果取多了*/{Loc(2,y1);printf("输入错误!请重新输入!");Loc(65,6);printf("   ");continue;}n=n-x;Loc(2,y1);y1+=2;printf("玩家取走了%d个石子,还剩余%d个",x,n);/*下面该电脑取走石子了*/Sleep(2000);x=(m+1)-x;n=n-x;/*电脑每次只要拿走m+1-x个就是必胜态*/Loc(2,y1);y1+=2;printf("电脑取走了%d个石子,还剩余%d个",x,n);Loc(65,6);printf("   ");}Loc(2,y1);printf("你输啦!再来一次吧?赢了会有大礼哦~");y1+=2;Loc(2,y1);printf("是否再来一把?(Y/N):");
}
void End()
{Loc(13,8);printf("感觉您的支持~!Thank you!~");Loc(13,12);printf("Made by 2013-3-19");Sleep(3000);
}
int main()
{char x[10]={'Y'};do{Welcome();GetNumber();Choice();BuildMap();GameStart();scanf("%s",x);system("cls");}while(x[0]=='Y');Loc(0,50);End();return 0;
}

这篇关于简单取石子游戏~博弈的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1146578

相关文章

利用Python编写一个简单的聊天机器人

《利用Python编写一个简单的聊天机器人》这篇文章主要为大家详细介绍了如何利用Python编写一个简单的聊天机器人,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 使用 python 编写一个简单的聊天机器人可以从最基础的逻辑开始,然后逐步加入更复杂的功能。这里我们将先实现一个简单的

使用IntelliJ IDEA创建简单的Java Web项目完整步骤

《使用IntelliJIDEA创建简单的JavaWeb项目完整步骤》:本文主要介绍如何使用IntelliJIDEA创建一个简单的JavaWeb项目,实现登录、注册和查看用户列表功能,使用Se... 目录前置准备项目功能实现步骤1. 创建项目2. 配置 Tomcat3. 项目文件结构4. 创建数据库和表5.

使用PyQt5编写一个简单的取色器

《使用PyQt5编写一个简单的取色器》:本文主要介绍PyQt5搭建的一个取色器,一共写了两款应用,一款使用快捷键捕获鼠标附近图像的RGB和16进制颜色编码,一款跟随鼠标刷新图像的RGB和16... 目录取色器1取色器2PyQt5搭建的一个取色器,一共写了两款应用,一款使用快捷键捕获鼠标附近图像的RGB和16

四种简单方法 轻松进入电脑主板 BIOS 或 UEFI 固件设置

《四种简单方法轻松进入电脑主板BIOS或UEFI固件设置》设置BIOS/UEFI是计算机维护和管理中的一项重要任务,它允许用户配置计算机的启动选项、硬件设置和其他关键参数,该怎么进入呢?下面... 随着计算机技术的发展,大多数主流 PC 和笔记本已经从传统 BIOS 转向了 UEFI 固件。很多时候,我们也

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核

Python开发围棋游戏的实例代码(实现全部功能)

《Python开发围棋游戏的实例代码(实现全部功能)》围棋是一种古老而复杂的策略棋类游戏,起源于中国,已有超过2500年的历史,本文介绍了如何用Python开发一个简单的围棋游戏,实例代码涵盖了游戏的... 目录1. 围棋游戏概述1.1 游戏规则1.2 游戏设计思路2. 环境准备3. 创建棋盘3.1 棋盘类

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ

poj2505(典型博弈)

题意:n = 1,输入一个k,每一次n可以乘以[2,9]中的任何一个数字,两个玩家轮流操作,谁先使得n >= k就胜出 这道题目感觉还不错,自己做了好久都没做出来,然后看了解题才理解的。 解题思路:能进入必败态的状态时必胜态,只能到达胜态的状态为必败态,当n >= K是必败态,[ceil(k/9.0),k-1]是必胜态, [ceil(ceil(k/9.0)/2.0),ceil(k/9.