寒假作业(蓝桥杯2016年省赛C++ A组第6题)

题意:现在小学的数学题目也不是那么好玩的。

看看这个寒假作业:

□ + □ = □

□ - □ = □

□ × □ = □

□ ÷ □ = □

每个方块代表1~13中的某一个数字,但不能重复。

比如:

6 + 7 = 13

9 - 8 = 1

3 * 4 = 12

10 / 2 = 5

以及:

7 + 6 = 13

9 - 8 = 1

3 * 4 = 12

10 / 2 = 5

就算两种解法。(加法,乘法交换律后算不同的方案)

你一共找到了多少种方案?

全排列+剪枝

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int a[20] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13};
bool vis[20];
int b[20];
int ans = 0;
void dfs(int s,int t){
    if(s == 12){
        if(b[9] / b[10] == b[11]){
            ans++;
        }
        return;
    }
    if(s == 3 && b[0] + b[1] != b[2])//剪枝
        return;
    if(s == 6 && b[3] - b[4] != b[5])
        return;
    if(s == 9 && b[6] * b[7] != b[8])
        return;
    for (int i = 0; i < t; i++){
        if(!vis[i]){
            vis[i] = true;
            b[s] = a[i];
            dfs(s + 1, t);
            vis[i] = false;
        }
    }
}
int main(){
    dfs(0, 13);
    cout << ans;
    return 0;
}
相关推荐
汉克老师9 小时前
CCF-NOI2025第二试题目与解析(第二题、集合(set))
c++·算法·noi·子集卷积·sos dp·mod 异常
Ayu阿予9 小时前
C++从源文件到可执行文件的过程
开发语言·c++
福尔摩斯张9 小时前
基于C++的UDP网络通信系统设计与实现
linux·c语言·开发语言·网络·c++·tcp/ip·udp
hkNaruto10 小时前
【规范】Linux平台C/C++程序版本发布调试规范手册 兼容银河麒麟
linux·c语言·c++
老王熬夜敲代码10 小时前
C++中的mutex、condition_val
c++·笔记·面试
闻缺陷则喜何志丹10 小时前
【计算几何 二分查找】P12261 [蓝桥杯 2024 国 Java B] 激光炮|普及+
c++·数学·蓝桥杯·计算几何·洛谷
Ivy_belief11 小时前
C++新特性汇总:涵盖C++11到C++23
java·c++·c++11·c++23
koddnty11 小时前
在c++中使用HOOK修改sleep函数
linux·c++
_OP_CHEN11 小时前
【算法基础篇】(三十一)动态规划之基础背包问题:从 01背包到完全背包,带你吃透背包问题的核心逻辑
算法·蓝桥杯·动态规划·背包问题·01背包·完全背包·acm/icpc
誰能久伴不乏11 小时前
深入理解 `poll` 函数:详细解析与实际应用
linux·服务器·c语言·c++·unix