24点游戏之思路

本文深入探讨了24点游戏的解决方案,采用递归算法处理数字运算组合,通过笛卡尔乘积原理去除重复配对,实现对任意四个数字进行加减乘除运算以达到24的目标值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

笛卡尔乘积,去掉i==j

就是所有可能配对


for i in range(len(nums)):
	for j in range(len(nums)):
		if i!=j:
			print((i,j))
			

那么我们只要任选一组做±*/四种操作的一种

'''
选取除了(nums[i], nums[j])之外的数字组成列表
'''
leftChoices = [ x[k] for k in range(len(nums)) if k!=j!=i ]

'''
新的列表就是:
'''
[nums[i]+nums[j]] + leftchoices
[nums[i]-nums[j]] + leftchoices
[nums[i]*nums[j]] + leftchoices
[nums[i]/nums[j]] + leftchoices

'''
注意了,i,j如果互换位置,那么其实第一个和第三个式子不会变化,因此可以随意限制搜索的时候,i>j 或者 i<j都可以

然后,除法要注意,除数不能为0,因此要加上,nums[j]!=0

现在nums变成了只有三个元素的列表,然后递归调用。
'''
'''
完整代码
'''
class solution()
	def judge24Point(self, nums):
		if len(nums)==0:
			return False
		def helper(nums):
			#递归出口
			if len(nums)==1:
				return abs(nums[0]-24)<1e-7
			for i in range(len(nums)):
				for j in range(len(nums)):
					if i!=j:
						left = [x[k] for k in range(len(nums)) if k!=j!=i]
						
						if i>j and helper(left + [nums[i]+nums[j]]):return True
						if i>j and helper(left + [nums[i]*nums[j]]):return True
						if helper(left + [nums[i]-nums[j]])return True
						if nums[j]>0 and helper(left + [nums[i]/nums[j]]):return True
			return False
		return helper(nums)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

万物琴弦光锥之外

给个0.1,恭喜老板发财

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值