【三国杀活动】C++代码破解曹瞒走华容道(广搜、状态压缩、二叉排序树)带界面

(写了个Qt界面)

问题描述

6×6的网格内,有竖条和横条,长度为2或3 竖条只能上下移动,横条只能左右移动 在给定步数内,使得绿色横条(即曹阿瞒有我良计取冀州便是易如反掌 )到达右端
(不想看只想要代码的点我)


首先建模,输入如下:

每行输入(x,y,dir,len)分别代表横条在第x行和第y列,dir为1代表为横条,为0代表竖条,len为横条的长度,最后一行以(-1,-1,-1,-1)结尾
然后输入步数step,要求在step内得到结果

输出:若有解,输出路径

样例1:

2 0 1 2
0 3 1 3
1 4 0 2
3 4 0 3
-1 -1 -1 -1
3
OOOBBB
OOOOCO
AAOOCO
OOOODO
OOOODO
OOOODO

BBBOOO
OOOOCO
AAOOCO
OOOODO
OOOODO
OOOODO

BBBOCO
OOOOCO
AAOOOO
OOOODO
OOOODO
OOOODO

BBBOCO
OOOOCO
OOOOAA
OOOODO
OOOODO
OOOODO

Success

样例2:

2 0 1 2
0 1 0 2
0 2 1 2
0 5 0 3
1 2 0 3
3 0 0 3
3 3 1 3
4 1 1 2
4 4 0 2
-1 -1 -1 -1
22
OBCCOD
OBEOOD
AAEOOD
FOEGGG
FHHOLO
FOOOLO

OBOCCD
OBEOOD
AAEOOD
FOEGGG
FHHOLO
FOOOLO
...(鉴于篇幅,省略)

CCEOLO
OOEOLO
OOEOAA
FGGGOD
FBOHHD
FBOOOD

Success

解:(1)状态压缩:棋盘一共6×6大小,也就是最多只有3 * 6 = 18个横条或竖条,每个横条的行数x固定,y变化,每个竖条的y固定,x变化,也就是说,可以用3位的数来表示横条的状态,long long 的数字类型一共有64位,也就是说我们可以用一个long long int 的数来代表棋盘的一个状态。
做法:图压缩成数的函数:

long compress()       //将当前状态压缩到long 
{
   
	long ans = 0;
//	cout<<batch_num<<'*';
	for(int i = 1;i <= batch_num;i++)
	{
   
		if(batches[i].dir)
			ans = ans | batches[i].y;
		else
			ans = ans | batches[i].x;
		if(i != batch_num)
		ans = ans << 3;
//		cout<<ans<<endl;
	}
	return ans;
}

(2)二叉排序树:将每个状态记录到二叉排序树里,查找的效率在O(logn),每次查一个状态是否已经出现过的时候,速度很快。
(3)横条竖条移动的模拟:这个简单。
(4

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
设二排序的二链表存储结构的类型定义如下: typedef struct node{ int data; //用整数表示一个结点的名 struct node *LChild,*RChild; //左右指针域 }BSTNode,*BSTree; 设计算法并编写程序求解以下几个问题。 8 12 14 10 7 3 15 6 2 4 1 5 11 9 13 16 13 (1)键盘输入一个元素序列创建一棵二排序,输出该二排序的中序遍历序列; 例如,若输入 45,24,55,12,37,53,60,23,40,70 则创建的二排序为: 输出结果为:12 23 24 37 40 45 53 55 60 70 (2)在(1)中所得的二排序中插入一个值为 58 的结点,再输出它的中序遍历序列,输出 结果为:12 23 24 37 40 45 53 55 58 60 70 (3)在(1)中所得的二排序中删除值为 45 的结点,再输出它的中序遍历序列,输出结果 为:12 23 24 37 40 53 55 58 60 70 (4)利用(1)中所得的二排序的所有叶子结点构造一个头结点的单链表 L。要求不能 破坏这棵二排序。所得的单链表 L 如下。 输出该链表各结点的值,输出结果为:23 40 53 70 (5)设计算法将(1)中所得的二排序的左右子进行交换,由于二是一种递归定义, 所以子的左右两棵子也要相交换,依此类推。最后输出所得到的二的中序遍历序列。 例如,经过上述操作后,(1)中所得的二排序变为如下形式。 输出该二的中序序列,结果为:70 60 55 53 45 40 37 24 23 12 (6)设计算法统计并输出(1)中所得的二排序中只有一个孩子结点的结点个数。输出结 果为:3(7)在(1)中所得的二排序中,设计算法并编写程序输出结点 40 的所有祖先结点。输 出结果为:45 24 37

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值