火柴游戏(博弈问题)

2024-02-15 05:48
文章标签 问题 游戏 博弈 火柴

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



这是一个纵横火柴棒游戏。
如图1,在3x4的格子中,游戏的双方轮流放置火柴棒。
其规则是:
1. 不能放置在已经放置了火柴棒的地方(即只能在空格中放置)。
2. 火柴棒的方向只能是竖直或水平放置。
3. 火柴棒不能与其它格子中的火柴“连通”。
所谓连通是指两根火柴棒可以连成一条直线,且中间没有其它不同方向的火柴“阻拦”。
例如:
图1所示的局面下,可以在C2位置竖直放置(为了方便描述格子位置,图中左、下都添加了标记),但不能水平放置,因为会与A2连通。
同样道理,B2,B3,D2此时两种方向都不可以放置。
但如果C2竖直放置后,D2就可以水平放置了,因为不再会与A2连通(受到了C2的阻挡)。
4. 游戏双方轮流放置火柴,不可以弃权,也不可以放多根。


如某一方无法继续放置,则该方为负(输的一方)。


游戏开始时可能已经放置了多根火柴。
你的任务是:编写程序,读入初始状态,计算出对自己最有利的放置方法并输出放置后的局面。
图1的局面表示为:
00-1
-000
0100
即用“0”表示空闲位置,用“1”表示竖直放置,用“-”表示水平放置。


解法不唯一,找到任意解法即可。


例如,局面:
0111
-000
-000
的解:
-111
-000
-000


再例如,局面:
1111
----
0010
的解:
1111
----

0110


import java.math.BigDecimal;
import java.math.BigInteger;
import java.util.Scanner;public class Main {public static void main(String[] args) { Scanner input = new Scanner(System.in);char[][] init = new char[3][4];init[0] = input.nextLine().trim().toCharArray();init[1] = input.nextLine().trim().toCharArray();init[2] = input.nextLine().trim().toCharArray();pan(init);}  //因为这个题需要求一个解法即可,所以用到两个相似的程序。方便在找出一个解后终止程序public static void pan(char[][] init){for(int i=0;i<3;i++){for(int j=0;j<4;j++){if(init[i][j]!='0')continue;try {if(!pan2(init)){show(init);return;}init[i][j] = '1';if(!pan2(init)){show(init);return;}init[i][j] = '-';} finally {// TODO: handle finally clauseinit[i][j] = '0';}}}}public static boolean pan2(char[][] init){for(int i=0;i<3;i++){//直接把所有一行的所有 0 替换掉 看看有没有存在连接在一起的--有就说明走上一步的人已经输了,返回true代表我赢了String s = new String(init[i]).replace("0","");if(s.contains("--"))return true;}for(int i=0;i<4;i++){//同理直接//把所有一列的所有 0 替换掉 看看有没有存在连接在一起的11有就说明走上一步的人已经输了,返回true代表我赢了String s = (""+init[0][i]+init[1][i]+init[2][i]).replace("0","");if(s.contains("11"))return true;}for(int i=0;i<3;i++){for(int j=0;j<4;j++){if(init[i][j]!='0')continue;try {init[i][j] = '-';if(!pan2(init)){return true;}init[i][j] = '1';if(!pan2(init)){return true;}} finally {// TODO: handle finally clauseinit[i][j] = '0';}}}return false;	}public static void show(char[][] arr){for(int i=0;i<3;i++){for(int j=0;j<4;j++){System.out.print(arr[i][j]);}System.out.println();}}}  

这篇关于火柴游戏(博弈问题)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

详谈redis跟数据库的数据同步问题

《详谈redis跟数据库的数据同步问题》文章讨论了在Redis和数据库数据一致性问题上的解决方案,主要比较了先更新Redis缓存再更新数据库和先更新数据库再更新Redis缓存两种方案,文章指出,删除R... 目录一、Redis 数据库数据一致性的解决方案1.1、更新Redis缓存、删除Redis缓存的区别二

oracle数据库索引失效的问题及解决

《oracle数据库索引失效的问题及解决》本文总结了在Oracle数据库中索引失效的一些常见场景,包括使用isnull、isnotnull、!=、、、函数处理、like前置%查询以及范围索引和等值索引... 目录oracle数据库索引失效问题场景环境索引失效情况及验证结论一结论二结论三结论四结论五总结ora

element-ui下拉输入框+resetFields无法回显的问题解决

《element-ui下拉输入框+resetFields无法回显的问题解决》本文主要介绍了在使用ElementUI的下拉输入框时,点击重置按钮后输入框无法回显数据的问题,具有一定的参考价值,感兴趣的... 目录描述原因问题重现解决方案方法一方法二总结描述第一次进入页面,不做任何操作,点击重置按钮,再进行下

解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题

《解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题》本文主要讲述了在使用MyBatis和MyBatis-Plus时遇到的绑定异常... 目录myBATis-plus-boot-starpythonter与mybatis-spring-b

mysql主从及遇到的问题解决

《mysql主从及遇到的问题解决》本文详细介绍了如何使用Docker配置MySQL主从复制,首先创建了两个文件夹并分别配置了`my.cnf`文件,通过执行脚本启动容器并配置好主从关系,文中还提到了一些... 目录mysql主从及遇到问题解决遇到的问题说明总结mysql主从及遇到问题解决1.基于mysql

如何测试计算机的内存是否存在问题? 判断电脑内存故障的多种方法

《如何测试计算机的内存是否存在问题?判断电脑内存故障的多种方法》内存是电脑中非常重要的组件之一,如果内存出现故障,可能会导致电脑出现各种问题,如蓝屏、死机、程序崩溃等,如何判断内存是否出现故障呢?下... 如果你的电脑是崩溃、冻结还是不稳定,那么它的内存可能有问题。要进行检查,你可以使用Windows 11

如何安装HWE内核? Ubuntu安装hwe内核解决硬件太新的问题

《如何安装HWE内核?Ubuntu安装hwe内核解决硬件太新的问题》今天的主角就是hwe内核(hardwareenablementkernel),一般安装的Ubuntu都是初始内核,不能很好地支... 对于追求系统稳定性,又想充分利用最新硬件特性的 Ubuntu 用户来说,HWEXBQgUbdlna(Har

MAVEN3.9.x中301问题及解决方法

《MAVEN3.9.x中301问题及解决方法》本文主要介绍了使用MAVEN3.9.x中301问题及解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录01、背景02、现象03、分析原因04、解决方案及验证05、结语本文主要是针对“构建加速”需求交

Nginx、Tomcat等项目部署问题以及解决流程

《Nginx、Tomcat等项目部署问题以及解决流程》本文总结了项目部署中常见的four类问题及其解决方法:Nginx未按预期显示结果、端口未开启、日志分析的重要性以及开发环境与生产环境运行结果不一致... 目录前言1. Nginx部署后未按预期显示结果1.1 查看Nginx的启动情况1.2 解决启动失败的

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

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