当前位置:首页 > 提高组 > NOIP 2008火柴棒等式题解(C++代码实现) 动态规划与枚举算法详解

NOIP 2008火柴棒等式题解(C++代码实现) 动态规划与枚举算法详解

3个月前 (06-11)

NOIP 2008火柴棒等式题解(C++代码实现)  动态规划与枚举算法详解 火柴棒等式 动态规划 枚举算法 第1张

一、题目解读

火柴棒等式问题(NOIP 2008,洛谷P1149)要求使用给定数量的火柴棒,构造形如 A + B = C 的等式,其中A、B、C均为整数,且火柴棒总数恰好等于输入值。需统计符合条件的等式数量。题目核心在于将数字拆解与火柴棒消耗建模为数学问题,寻找高效解法。

二、解题思路

采用枚举 + 火柴棒计数策略:

1. 映射关系构建:预计算0-9每个数字所需的火柴棒数量(如6根火柴构成“0”,2根构成“1”等),存储于match_count数组,降低重复计算开销。

2. 双层循环枚举A、B:限定A、B范围(0-1111)以避免溢出,计算C = A + B。

3. 总火柴棒计算:通过get_match_num函数累加A、B、C各自的火柴棒数,并额外计入“+”和“=”符号所需的4根火柴。

4. 匹配统计:若总火柴棒数等于输入n,则计数加1。

三、解题步骤

1. 初始化:定义输入n,计数器count,及火柴棒映射数组match_count。

2. 双层循环遍历A、B:

    外层循环A(0-1111),内层循环B(0-1111),确保组合覆盖所有可能。

3. 计算C及总火柴棒:

    通过C = A + B得到结果,调用get_match_num函数分别计算A、B、C的火柴棒数,并计入符号(+和=)的固定消耗。

4. 条件判断:若总火柴棒数等于n,则count++。

5. 输出结果:最终输出符合条件的等式数量。

四、代码与注释

#include <iostream>
using namespace std;

// 每个数字0-9所需的火柴棒数量
const int match_count[10] = {6, 2, 5, 5, 4, 5, 6, 3, 7, 6};

// 计算一个数字需要的火柴棒总数
int get_match_num(int num) {
    if (num == 0) return match_count[0];
    int total = 0;
    while (num > 0) {
        // 逐位累加火柴棒数(如123分解为1+2+3的火柴棒)
        total += match_count[num % 10];
        num /= 10;
    }
    return total;
}

int main() {
    int n;
    cin >> n;
    int count = 0;
    
    // 遍历所有可能的A和B组合
    for (int a = 0; a <= 1111; ++a) {
        for (int b = 0; b <= 1111; ++b) {
            int c = a + b;
            // 计算总火柴棒:A + B + C + '+' + '=' (符号需4根)
            int total = get_match_num(a) + get_match_num(b) + get_match_num(c) + 4;
            if (total == n) {
                count++;
            }
        }
    }
    
    cout << count << endl;
    return 0;
}

五、总结

该解法巧妙利用预计算与枚举结合,将火柴棒问题转化为数字拆解与累加。通过限定A、B范围避免无效计算,get_match_num函数优化了多位数字的火柴棒统计过程。尽管时间复杂度为O(n²),但通过空间换时间的策略(静态数组)显著提升效率。对于算法竞赛中的资源限制场景,此思路具有普适性,可作为类似问题的基准解法。


原创内容 转载请注明出处

分享给朋友:

相关文章

GESP2023年六级真题解析:动态规划解决小杨买饮料问题(洛谷3873)

GESP2023年六级真题解析:动态规划解决小杨买饮料问题(洛谷3873)

一、题目解读小杨买饮料是GESP 2023年六级认证考试中的一道经典动态规划题目,考察学生对背包问题的理解和应用能力。题目描述小杨需要购买n种饮料,每种饮料有特定的体积w和价格v,他要在不超过容量l的...

2024年GESP五级武器强化(洛谷B4071)解题代码C++版

2024年GESP五级武器强化(洛谷B4071)解题代码C++版

一、题目解读    2024年GESP(青少年软件编程能力等级考试)五级中的“武器强化”(洛谷平台题目编号B4071)是一道典型的算法优化问题。题目要求通过合理...

LeetCode 120题三角形最小路径和最优解法:动态规划详解与代码实现

LeetCode 120题三角形最小路径和最优解法:动态规划详解与代码实现

一、题目解读LeetCode 120题“三角形最小路径和”要求给定一个由数字组成的三角形,从顶部开始向下移动,每次可向左或向右移动一格,计算从顶至底的最小路径和。三角形以二维向量形式给出,每层元素数量...

洛谷P4551题解题报告:图论与Trie树优化异或路径问题的实战解析

洛谷P4551题解题报告:图论与Trie树优化异或路径问题的实战解析

一、题目解读洛谷P4551题要求在一个无向图中,寻找任意两点路径权值异或后的最大值。题目输入为图的边信息(点数n和n-1条边),每条边包含起点、终点及权值。需输出所有路径中权值异或的最大值。问题核心在...

洛谷P4999题解析:动态规划求解数字拆分与求和问题(附代码)

洛谷P4999题解析:动态规划求解数字拆分与求和问题(附代码)

一、题目解读洛谷P4999题要求处理给定区间 [L, R] 内数字的拆分与求和问题。每个数字需拆分为其各位数字之和,并计算区间内所有数字之和的累加结果。题目需考虑大数情况,并采用取模运算(MOD=1e...

力扣931题最小下降路径和解析 动态规划解法 LeetCode解题技巧

力扣931题最小下降路径和解析 动态规划解法 LeetCode解题技巧

一、题目解读力扣931题「Minimum Falling Path Sum」(最小下降路径和)要求在一个n x n的整数矩阵中,计算从顶部到底部的最小路径和。路径只能从每个位置向下或对角线移动(即向下...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。