一道很有意思的题目嘞。



这道题目看起来,用搜索似乎无疑了。

我想了这样一个办法(看了很多博客似乎都没用这种方法),可能是觉得太麻烦了吧:

1、我们先把0到9的数字排列,找出排列消耗火柴等于0的序列。这就是dfs函数的作用。

2、将找出的序列传入check函数中,枚举第一个数的长度,在枚举第二个数的长度,然后检查a+b是否等于c。

3、关键是,要满足非个位数不能为0,就是这个语句了。



其中d[0]记录第一个数的长度,d[1]记录第二个数的长度,num表示序列总长度。

代码如下:

#include <bits/stdc++.h>
using namespace std;
int a[13]={6,2,5,5,4,5,6,3,7,6};
int b[100],d[4];//数组b储存序列,数组d储存第
一个数和第二个数的长度
int n,sumn=0;
void check(int num,int pos,int gg)//num为从dfs传来的序列长度,上一个数的长度截止到pos,gg表示已经匹配的数-1。
{
if(gg==2)
{
int q=0,w=0,e=0;
if(d[0]>=1&&b[0]==0)
return;
if(d[1]-d[0]>1&&b[d[0]+1]==0)
return;
if(num-d[1]>1&&b[d[1]+1]==0)
return;
for(int i=0;i<=d[0];i++)
q=q*10+b[i];
for(int i=d[0]+1;i<=d[1];i++)
w=w*10+b[i];
for(int i=d[1]+1;i<=num;i++)
e=e*10+b[i];
if(q+w==e)
{
sumn++;
}
return;
}
for(int i=pos;i<num;i++)
{
d[gg]=i;
check(num,i+1,gg+1);
d[gg]=0;
}
}
void dfs(int n,int num)
{
if(n==0)
{
check(num-1,0,0);
return;
}
if(n<2)
return;
for(int i=0;i<=9;i++)
{
if(n>=a[i])
{
b[num]=i;
dfs(n-a[i],num+1);
b[num]=0;
}
}
}
int main()
{
cin>>n;
sumn=0;
dfs(n-4,0);
cout<<sumn<<endl;
}

当然,递归写法还有一种,我给个链接大家自己看吧,

纯递归写法

但是,这题有更简单的方法。

我们直接从用两个for循环枚举a和b



其中cal为计算数字需要消耗的火柴数目。为什么上限取到1111呢?题目中火柴只有24根,可用的只有20根。1111需要8根火柴,0需要5根,若满足a+b=c,c也为1111,这里加起来21根。所以在范围内,我们都可以枚举到。

代码:

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
int num[11] = {6,2,5,5,4,5,6,3,7,6},n,ans = 0;
int find3(int x)
{
if(x == 0)
return 6;
int an = 0;
while(x)
{
an += num[x % 10];
x /= 10;
}
return an;
}
void find2(int cnt,int a,int x,int k)//第二位数;
{
if(find3(a + x) == cnt)
ans ++;
if(k)//避免首位数为0;
for(int i = 0;i <= 9;i ++)
{
if(cnt - num[i] >= 2)//至少还要放1个1;
find2(cnt - num[i],a,x * 10 + i,1);
}
}
void find(int cnt,int x,int k)//第一位数;
{
for(int i = 0;i <= 9;i ++)
if(n - num[i] >= 2)
find2(cnt - num[i],x,i,i);
if(k)//避免首位数为0;
for(int i = 0;i <= 9;i ++)
{
if(cnt - num[i] >= 4)
find(cnt - num[i],x * 10 + i,1);
}
}
int main()
{
scanf("%d",&n);
n -= 4;// ‘+’ 和 ‘=’;
for(int i = 0;i <= 9;i ++)
if(n - num[i] >= 4)//至少还要放2个1;
find(n - num[i],i,i);
printf("%d",ans);
}

洛谷p1149的更多相关文章

  1. 洛谷 P1149 火柴棒等式

    嗯....   这道题好讨厌啊!!!!   一开始莫名RE,然后发现数组小了,然后发现后面几个点总是WA,原来推的少了....   并且这道题的思路真的好水啊!!   先看一下题: 题目描述 给你n根 ...

  2. (水题)洛谷 - P1149 - 火柴棒等式

    https://www.luogu.org/problemnew/show/P1149 一开始还分类重复了.在非0的dfs中居然赋值了0,脑残得一笔. 其实就按 $lead0$ 分类就好了, $lea ...

  3. 用Python写算法题--洛谷P1149 火柴棒等式

    题目 题目来源 P1149 火柴棒等式,https://www.luogu.org/problem/P1149 题目描述 给你n根火柴棍,你可以拼出多少个形如"A+B=C"的等式? ...

  4. 洛谷P1149 火柴棒等式

    题目描述 给你n根火柴棍,你可以拼出多少个形如“A+B=C”的等式?等式中的A.B.C是用火柴棍拼出的整数(若该数非零,则最高位不能是0).用火柴棍拼数字0-9的拼法如图所示: 注意: 1.加号与等号 ...

  5. [NOIP2008] 提高组 洛谷P1149 火柴棒等式

    题目描述 给你n根火柴棍,你可以拼出多少个形如“A+B=C”的等式?等式中的A.B.C是用火柴棍拼出的整数(若该数非零,则最高位不能是0).用火柴棍拼数字0-9的拼法如图所示: 注意: 加号与等号各自 ...

  6. Java实现 洛谷 P1149 火柴棒等式

    import java.util.HashMap; import java.util.Iterator; import java.util.LinkedList; import java.util.S ...

  7. 洛谷P1149.火柴棒等式(暴力搜索)

    题目描述 给你n根火柴棍,你可以拼出多少个形如"A+B=C"的等式?等式中的A.B.C是用火柴棍拼出的整数(若该数非零,则最高位不能是0).用火柴棍拼数字0-9的拼法如图所示: 注 ...

  8. 洛谷1640 bzoj1854游戏 匈牙利就是又短又快

    bzoj炸了,靠离线版题目做了两道(过过样例什么的还是轻松的)但是交不了,正巧洛谷有个"大牛分站",就转回洛谷做题了 水题先行,一道傻逼匈牙利 其实本来的思路是搜索然后发现写出来类 ...

  9. 洛谷P1352 codevs1380 没有上司的舞会——S.B.S.

    没有上司的舞会  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond       题目描述 Description Ural大学有N个职员,编号为1~N.他们有 ...

随机推荐

  1. 通过powershell查询OU中被禁用的AD账号,并删除他们的所属组

    这个需求可以通过两个方向来实现1.找到禁用的账号,删除除domain users外的所有组,脚本内容如下 #导入AD模块import-module ActiveDirectory #被禁用户$user ...

  2. C++_编程前奏

    计算机硬件系统 计算机操作系统的五大组成部分 计算机操作系统的组成部分 构成 控制器 指令寄存器(IR)/程序计数器(PC)/操作控制器(OC) 运算器 算数逻辑单元/累加器/状态寄存器/通用寄存器 ...

  3. Keepalived实现Nginx负载均衡高可用

    第一章:keepalived介绍 VRRP协议 目的就是为了解决静态路由单点故障问题的 第二章: keepalived工作原理 2.1 作为系统网络服务的高可用功能(failover) keepali ...

  4. Python队列的三种队列方法

    今天讲一下队列,用到一个python自带的库,queue 队列的三种方法有: 1.FIFO先入先出队列(Queue) 2.LIFO后入先出队列(LifoQueue) 3.优先级队列(PriorityQ ...

  5. [算法]Huffman树(哈夫曼树)

    目录 一.关于Huffman树 二.具体实现 例1:P1090 合并果子 例2:P2168 [NOI2015]荷马史诗 一.关于Huffman树 Huffman树(哈夫曼树)可以解决下述问题: 一颗\ ...

  6. 如何将一个div水平垂直居中?6种方法做推荐

    方案一: div绝对定位水平垂直居中[margin:auto实现绝对定位元素的居中], 兼容性:,IE7及之前版本不支持 div{ width: 200px; height: 200px; backg ...

  7. 【WPF学习】第六十七章 创建自定义面板

    前面两个章节分别介绍了两个自定义控件:自定义的ColorPicker和FlipPanel控件.接下来介绍派生自定义面板以及构建自定义绘图控件. 创建自定义面板是一种特殊但较常见的自定义控件开发子集.前 ...

  8. ExceptionInChainedOperatorException:flink写hbase对于null数据导致数据导致出现异常

    使用的flink版本:1.9.1 异常描述 需求: 从kafka读取一条数据流 经过filter初次筛选符合要求的数据 然后通过map进行一次条件判断再解析.这个这个过程中可能返回null或目标输出o ...

  9. [PHP] excel 的导入导出

    其实excel导入导出挺简单的,导出最简单! 其原理都是把数据读出来,导出是从数据库中读出数据,导入是从文件读出数据! 导出写入文件,导入写入数据库! 但是在导入表的时候,用的是PHPExcel, 不 ...

  10. bash cookbook

    目录 简介 变量 静态变量 变量操作 数组 应用 四则运算 条件测试 整数测试 文件测试 字符测试 组合条件测试 选择语句 循环语句 for--有限循环 while--无线循环 until conti ...