一道很有意思的题目嘞。



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

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

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. node实现防盗链

    什么是防盗链 盗链,顾名思义就是盗窃链接,就是在他人未经允许的情况下,去使用他人站点的任何图片,视频,内容等资源,来借此提升已用的站点的活跃度,严重损坏了别人的利益.那么防盗链就是采用一些办法阻止自己 ...

  2. 智能指针 shared_ptr

    1.不支持数组 2.c++11支持make_shared,分配一次内存,构造函数为private和proteced时不能调用. 3.new初始化分配两次内存,一.分配数据块内存,二.分配控制块内存

  3. Mac Jenkins+fastlane 简单几步实现iOS自动化打包发布 + jenkins节点设置

    最近在使用jenkins 实现ios自动化打包发布蒲公英过程实践遇到了一些坑,特意记录下来方便有需要的人. 进入正题: 一.安装Jenkins 1.Mac上安装Jenkins 遇到到坑 因为 Jenk ...

  4. docker深入学习

    docker深入学习 一.容器的介绍和容器的发展史 为什么要学习容器? 在openstack之后,目前互联网最火热的技术莫过于docker容器了,早在2015年,京东技术备战双11就是使用了10万+D ...

  5. 多线程设置flag标志位实现同步

    信号灯解决同步问题 我尽量注释了代码,可以很容易理解了. package Thread; /** * 信号灯 * 借助标志位 */ public class FlagThread { public s ...

  6. 获取SVG中g标签的宽度高度及位置坐标

    1. 问题的出现 对于普通的HTML元素,有很多获得其宽度width.高度height.距左left.距顶top等属性的方法: 类似offsetWidth,clientWidth,width之类的,通 ...

  7. work of 1/5/2016

    part 组员                今日工作              工作耗时/h 明日计划 工作耗时/h    UI 冯晓云 UI页面切换,词本显示下滑条     6 继续下滑条等增删补 ...

  8. adb命令查看手机应用内存使用情况

    adb shell回车 一.procrank VSS >= RSS >= PSS >= USSVSS - Virtual Set Size 虚拟耗用内存(包含共享库占用的内存)是单个 ...

  9. Linux服务器压力测试总结(CPU、Memory、IO等)

    测试工具:sysbench.memtester.htop 1.htop安装使用 yum install ncurses-devel # 安装依赖包 tar zxvf htop-2.2.0.tar.gz ...

  10. CVE-2019-1388:Windows UAC 本地提权复现

    0x01 简介 用户帐户控制(User Account Control,简写作UAC)是微软公司在其Windows Vista及更高版本操作系统中采用的一种控制机制.其原理是通知用户是否对应用程序使用 ...