C#实现的24点游戏实例详解
作者:北风其凉 发布时间:2023-03-01 16:38:51
标签:C#,游戏
本文实例分析了C#实现的24点游戏。分享给大家供大家参考。具体如下:
1. 24点游戏规则及算法
规则:给出4个自然数,找出能够求出24的四则运算式,要求数字不能重复使用
分析:
本算法是一种暴力求解法:
给出任意两个数字,可以进行6种四则运算,求出最多6个值。以数字a和b为例,有:
加(a+b)、减(a-b)、被减(b-a)、乘以(a*b)、除以(a/b)和除(b/a)
abcd共计四个数,如果顺序固定,则有5种计算顺序(★代表上面6种四则运算中的一种):
((a★b)★c)★d、(a★b)★(c★d)、(a★(b★c))★d、a★((b★c)★d)、a★(b★(c★d))
给出的四个数字,n1n2n3n4,有4*3*2=24种全排列的方法
2. 相关函数
/// <summary>
/// 判断abcd四个数进行任意四则运算后能不能得出24,每个数字只能用一次
/// </summary>
/// <param name="a">数字a</param>
/// <param name="b">数字b</param>
/// <param name="c">数字c</param>
/// <param name="d">数字d</param>
/// <param name="expression"></param>
/// <returns></returns>
private static bool Try24(int a, int b, int c, int d, ref string expression)
{
//a字头
if (TryEach(a, b, c, d, ref expression)) return true;
if (TryEach(a, b, d, c, ref expression)) return true;
if (TryEach(a, c, b, d, ref expression)) return true;
if (TryEach(a, c, d, b, ref expression)) return true;
if (TryEach(a, d, b, c, ref expression)) return true;
if (TryEach(a, d, c, b, ref expression)) return true;
//b字头
if (TryEach(b, a, c, d, ref expression)) return true;
if (TryEach(b, a, d, c, ref expression)) return true;
if (TryEach(b, c, a, d, ref expression)) return true;
if (TryEach(b, c, d, a, ref expression)) return true;
if (TryEach(b, d, a, c, ref expression)) return true;
if (TryEach(b, d, c, a, ref expression)) return true;
//c字头
if (TryEach(c, a, b, d, ref expression)) return true;
if (TryEach(c, a, d, b, ref expression)) return true;
if (TryEach(c, b, a, c, ref expression)) return true;
if (TryEach(c, b, c, a, ref expression)) return true;
if (TryEach(c, d, a, b, ref expression)) return true;
if (TryEach(c, d, b, a, ref expression)) return true;
//d字头
if (TryEach(d, a, b, c, ref expression)) return true;
if (TryEach(d, a, c, b, ref expression)) return true;
if (TryEach(d, b, a, c, ref expression)) return true;
if (TryEach(d, b, c, a, ref expression)) return true;
if (TryEach(d, c, a, b, ref expression)) return true;
if (TryEach(d, c, b, a, ref expression)) return true;
return false;
}
/// <summary>
/// 判断指定顺序的四个数abcd进行任意四则运算后能不能得出24,每个数字只能用一次
/// </summary>
/// <param name="a">数字1</param>
/// <param name="b">数字2</param>
/// <param name="c">数字3</param>
/// <param name="d">数字4</param>
/// <param name="expression"></param>
/// <returns></returns>
private static bool TryEach(int a, int b, int c, int d, ref string expression)
{
expression = "";
//两个数可以做6种运算:加、减、被减、乘以、除以、除
//四个数共可以进行6*6*6=216种不同次序的四则运算
//初始化数组
for (int i = 0; i < 6 * 6 * 6; i++)
{
//a与b间的运算符:i / 36
//b与c间的运算符:i % 36 / 6
//c与d间的运算符:i % 6
//1.运算顺序:a和b,再和c,再和d
{
string expression1 = "", expression2 = "";
int temp1 = ResultOf(a, b, i / 36, ref expression1);
int temp2 = ResultOf(temp1, c, i % 36 / 6, ref expression2, expression1);
int result = ResultOf(temp2, d, i % 6, ref expression, expression2);
if (result == 24) return true;
}
//2.运算顺序:a和b,c和d,前面部分和后面部分
{
string expression1 = "", expression2 = "";
int temp1 = ResultOf(a, b, i / 36, ref expression1);
int temp2 = ResultOf(c, d, i % 6, ref expression2);
int result = ResultOf(temp1, temp2, i % 36 / 6,
ref expression, expression1, expression2);
if (result == 24) return true;
}
//3.运算顺序:b和c运算,再与a运算,再与d运算
{
string expression1 = "", expression2 = "";
int temp1 = ResultOf(b, c, i % 36 / 6, ref expression1);
int temp2 = ResultOf(a, temp1, i / 36, ref expression2, "", expression1);
int result = ResultOf(temp2, d, i % 6, ref expression, expression2);
if (result == 24) return true;
}
//4.运算顺序:b和c运算,再与d运算,再与a运算
{
string expression1 = "", expression2 = "";
int temp1 = ResultOf(b, c, i % 36 / 6, ref expression1);
int temp2 = ResultOf(temp1, d, i % 6, ref expression2, expression1);
int result = ResultOf(a, temp2, i / 36, ref expression, "", expression2);
if (result == 24) return true;
}
//5.运算顺序:c和d运算,再和b运算,再和a运算
{
string expression1 = "", expression2 = "";
int temp1 = ResultOf(c, d, i % 6, ref expression1);
int temp2 = ResultOf(b, temp1, i % 36 / 6, ref expression2, "", expression1);
int result = ResultOf(a, temp2, i / 36, ref expression, "", expression2);
if (result == 24) return true;
}
}
expression = "Abandoned";
return false;
}
/// <summary>
/// 求两数进行某一四则运算后的结果
/// </summary>
/// <param name="x">数字1</param>
/// <param name="y">数字2</param>
/// <param name="method">(0-5分别代表:加、减、被减、乘以、除以、除)</param>
/// <param name="expression">返回的表达式</param>
/// <param name="expressionLeft">数字1表达式</param>
/// <param name="expressionRight">数字2表达式</param>
/// <returns></returns>
private static int ResultOf(int x, int y, int method,
ref string expression, string expressionLeft = "", string expressionRight = "")
{
//左右表达式之前被判定为无效则不计算,除数为0时不计算
if (expressionLeft == "Abandoned" || expressionRight == "Abandoned" ||
(x == 0 && method == 5) || (y == 0 && method == 4))
{
expression = "Abandoned";
return -1;
}
int result = 0;
switch (method)
{
case 0:
{
//加
result = x + y;
expression = string.Format("{0}+{1}",
expressionLeft == "" ? x.ToString() : expressionLeft,
expressionRight == "" ? y.ToString() : expressionRight);
}
break;
case 1:
{
//减
result = x - y;
expression = string.Format("{0}-{1}",
expressionLeft == "" ? x.ToString() : expressionLeft,
expressionRight == "" ? y.ToString() : expressionRight);
}
break;
case 2:
{
//被减
result = y - x;
expression = string.Format("{1}-{0}",
expressionLeft == "" ? x.ToString() : expressionLeft,
expressionRight == "" ? y.ToString() : expressionRight);
}
break;
case 3:
{
//乘以
result = x * y;
expression = string.Format("({0})*({1})",
expressionLeft == "" ? x.ToString() : expressionLeft,
expressionRight == "" ? y.ToString() : expressionRight);
}
break;
case 4:
{
//除以
if (x % y == 0)
{
result = x / y;
expression = string.Format("({0})/({1})",
expressionLeft == "" ? x.ToString() : expressionLeft,
expressionRight == "" ? y.ToString() : expressionRight);
}
else
{
expression = "Abandoned";
}
}
break;
case 5:
{
//除
if (y % x == 0)
{
result = y / x;
expression = string.Format("({1})/({0})",
expressionLeft == "" ? x.ToString() : expressionLeft,
expressionRight == "" ? y.ToString() : expressionRight);
}
else
{
expression = "Abandoned";
}
}
break;
}
//运算不合法,则返回-1,表达式为Abandoned,
if (expression == "Abandoned")
{
return -1;
}
return result;
}
3. Main函数调用
static void Main(string[] args)
{
string s = "";
bool try24;
try24 = Try24(1, 2, 3, 4, ref s); Console.WriteLine("1,2,3,4: " + s);
try24 = Try24(1, 3, 5, 7, ref s); Console.WriteLine("1,3,5,7: " + s);
try24 = Try24(2, 3, 6, 4, ref s); Console.WriteLine("2,3,6,4: " + s);
try24 = Try24(5, 7, 9, 4, ref s); Console.WriteLine("5,7,9,4: " + s);
try24 = Try24(6, 3, 4, 5, ref s); Console.WriteLine("6,3,4,5: " + s);
try24 = Try24(9, 5, 2, 7, ref s); Console.WriteLine("9,5,2,7: " + s);
try24 = Try24(4, 9, 8, 3, ref s); Console.WriteLine("4,9,8,3: " + s);
try24 = Try24(4, 9, 8, 2, ref s); Console.WriteLine("4,9,8,2: " + s);
try24 = Try24(10, 10, 10, 10, ref s); Console.WriteLine("10,10,10,10: " + s);
Console.ReadLine();
}
4. 程序运行结果:
希望本文所述对大家的C#程序设计有所帮助。


猜你喜欢
- XML作为一种业界公认的数据交换格式,在各个平台与语言之上,都有广泛使用和实现。其标准型,可靠性,安全性......毋庸置疑。在androi
- 介绍无论是在WPF中还是WinForm中,都有用户控件(UserControl)和自定义控件(CustomControl),这两种控件都是对
- 本文实例为大家分享了openoffice+jodconverter-code-3.0-bate4实现ppt转图片的具体代码,供大家参考,具体
- 这篇文章主要介绍了Springboot打包部署代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋
- 本文实例为大家分享了UnityShader实现运动模糊的具体代码,供大家参考,具体内容如下原理:像素的当前帧的NDC坐标(x,y
- 我们在Android开发中总能看到程序的log日志内容充满了屏幕
- File 类:文件和目录路径名的抽象表示。注意:File 类只能操作文件的属性,文件的内容是不能操作的。1、File 类的字段我们知道,各个
- 今天一上班 被github上的一篇名为《教你用python玩跳一跳》吸引,它的星也瞬间从3400涨到4400 原作者主要就是用py
- 一、雪花算法datacenterId重复问题华为云的服务器的/etc/hosts中都会生成一条 127.0.1.1 hostname的记录
- 本文实例讲述了java实现求两个字符串最长公共子串的方法。分享给大家供大家参考,具体如下:这个是华为OJ上的一道题目。首先,如果我们用jav
- 简介一般情况下我们在flutter中搭建的app基本上都是用的是MaterialApp这种设计模式,MaterialApp中为我们接下来使用
- 一、常规形式1 项目结构2 配置文件及环境设置(1)配置文件# 应用服务 WEB 访问端口server.port=8080# spring
- 废话不多说了,先给大家上左右无限滑动的代码了。1.左右无限滑动public class MainActivity extends AppCo
- 1 框架组成SpringSpringMVCMyBatis2 所需工具Mysql 8.0.15数据库管理系统,创建数据库Tomcat 8.5.
- Android 实现获取手机里面的所有图片详解及实例实现代码:public class MainActivity extends Activ
- 前言大家都知道Android Studio目前已经更新到2.0 Preview 6了,作为Google大力推崇的开发工具,相对于Eclips
- 提供表示 Windows 注册表中的根项的 RegistryKey 对象,并提供访问项/值对的 static&
- 前言:在Java项目中,有两个主要的构建系统:Gradle和Maven。构建系统主要管理潜在的复杂依赖关系并正确编译项目。还可以将已编译的项
- 这篇文章主要介绍了Spring 事件Application Event原理详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定
- 之前一直使用各种报表工具,如RDLC、DevExpress套件的XtraReport报表,在之前一些随笔也有介绍,最近接触锐浪的Grid++