679. 24 点游戏

679. 24 点游戏


题目链接:679. 24 点游戏

代码如下:

cpp 复制代码
//参考链接:https://leetcode.cn/problems/24-game/solutions/3756006/mei-ci-he-bing-liang-zhang-pai-di-gui-xi-0sdu
class Solution {
public:
	bool judgePoint24(vector<int>& cards) {
		vector<double> a(cards.begin(),cards.end());
		return dfs(a);
	}

private:
	const double EPS = 1e-9;
	
	bool dfs(vector<double>& cards) {
		int n = cards.size();
		if (n == 1) {
			return abs(cards[0] - 24) < EPS; // 如果只剩一个数,判断是否接近 24
		}

		//选两张牌 x=cartds[i]和y=cards[j],进行四则运算
		for (int i = 0;i < n;i++) {
			double x = cards[i];
			for (int j = i + 1;j < n;j++) {
				double y = cards[j];
			
				//六种情况:加减乘除,其中减和除都有两种不同的顺序
				vector<double> candidates = { x + y,x - y,y - x,x * y };
				if (abs(y) > EPS) {
					candidates.push_back(x / y);
				}
				if (abs(x) > EPS) {
					candidates.push_back(y / x);
				}

				auto new_cards = cards;
				new_cards.erase(new_cards.begin() + j); // 移除第 j 张牌
				for (double res : candidates) {
					new_cards[i] = res; // 将结果放在第 i 张牌的位置
					if (dfs(new_cards)) {
						return true;
					}
				}
			}
		}
		return false; // 如果没有找到满足条件的组合,返回 false
	}
};
相关推荐
爱和冰阔落3 分钟前
【Linux系统编程】环境变量深度解析——从 fork 继承到 export 内建命令,两张表打通进程上下文
linux·c++·环境变量·系统调用
流浪0014 分钟前
C++篇:深入理解 C++ 智能指针:从裸指针到 RAII 的蜕变
开发语言·c++
丘山望岳6 分钟前
二叉搜索双壁——map和set
开发语言·数据结构·c++
QiLinkOS8 分钟前
合肥气链科技有限公司创办与未来技术应用
c语言·数据结构·c++·人工智能·单片机·嵌入式硬件·算法
郝学胜-神的一滴21 分钟前
Qt 高级开发 016:半内存管理机制
开发语言·c++·qt·程序人生·用户界面
会编程的土豆23 分钟前
Go 语言匿名函数详解
c++·golang·xcode
会编程的土豆25 分钟前
Go 语言闭包(Closure)详解
c++·golang·xcode
不吃土豆的马铃薯39 分钟前
高性能服务器程序框架详解(包括Reactor,有限状态机等)
linux·服务器·开发语言·网络·c++
郝学胜-神的一滴1 小时前
Qt 高级开发 020:水平布局手写代码实战
开发语言·c++·qt·系统架构·软件构建·用户界面
小欣加油1 小时前
leetcode2126 摧毁小行星
数据结构·c++·算法·leetcode·职场和发展