洛谷p1149
一道很有意思的题目嘞。

这道题目看起来,用搜索似乎无疑了。
我想了这样一个办法(看了很多博客似乎都没用这种方法),可能是觉得太麻烦了吧:
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的更多相关文章
- 洛谷 P1149 火柴棒等式
嗯.... 这道题好讨厌啊!!!! 一开始莫名RE,然后发现数组小了,然后发现后面几个点总是WA,原来推的少了.... 并且这道题的思路真的好水啊!! 先看一下题: 题目描述 给你n根 ...
- (水题)洛谷 - P1149 - 火柴棒等式
https://www.luogu.org/problemnew/show/P1149 一开始还分类重复了.在非0的dfs中居然赋值了0,脑残得一笔. 其实就按 $lead0$ 分类就好了, $lea ...
- 用Python写算法题--洛谷P1149 火柴棒等式
题目 题目来源 P1149 火柴棒等式,https://www.luogu.org/problem/P1149 题目描述 给你n根火柴棍,你可以拼出多少个形如"A+B=C"的等式? ...
- 洛谷P1149 火柴棒等式
题目描述 给你n根火柴棍,你可以拼出多少个形如“A+B=C”的等式?等式中的A.B.C是用火柴棍拼出的整数(若该数非零,则最高位不能是0).用火柴棍拼数字0-9的拼法如图所示: 注意: 1.加号与等号 ...
- [NOIP2008] 提高组 洛谷P1149 火柴棒等式
题目描述 给你n根火柴棍,你可以拼出多少个形如“A+B=C”的等式?等式中的A.B.C是用火柴棍拼出的整数(若该数非零,则最高位不能是0).用火柴棍拼数字0-9的拼法如图所示: 注意: 加号与等号各自 ...
- Java实现 洛谷 P1149 火柴棒等式
import java.util.HashMap; import java.util.Iterator; import java.util.LinkedList; import java.util.S ...
- 洛谷P1149.火柴棒等式(暴力搜索)
题目描述 给你n根火柴棍,你可以拼出多少个形如"A+B=C"的等式?等式中的A.B.C是用火柴棍拼出的整数(若该数非零,则最高位不能是0).用火柴棍拼数字0-9的拼法如图所示: 注 ...
- 洛谷1640 bzoj1854游戏 匈牙利就是又短又快
bzoj炸了,靠离线版题目做了两道(过过样例什么的还是轻松的)但是交不了,正巧洛谷有个"大牛分站",就转回洛谷做题了 水题先行,一道傻逼匈牙利 其实本来的思路是搜索然后发现写出来类 ...
- 洛谷P1352 codevs1380 没有上司的舞会——S.B.S.
没有上司的舞会 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description Ural大学有N个职员,编号为1~N.他们有 ...
随机推荐
- 并发系列64章(TPL 数据流)第七章
前言 什么是TPL?全称:transmission control protocol 传输层对应于OSI七层参考模型的传输层,它提供两种端到端的通信服务. 然后思维方式回到为什么有这个TPL 数据流上 ...
- Bat 脚本学习 (基础篇)
[转]Bat 脚本学习 2015-01-05 14:13 115人阅读 评论(0) 收藏 举报 基础部分: ============================================== ...
- elementUI踩坑
1.滚动条消失,body中莫名出现行内样式overflow: hidden; 在做某个图片上传,显示功能出现的问题.控制台并没有报错,代码也并无相关操作 必须重新刷新页面之后滚动条才会显示出来 几天后 ...
- AJ学IOS(56)网络基础以及如何搭建服务器
AJ分享,必须精品 一:为什么要学习网络编程 关于这个问题,为什么要学习网络编程,AJ的理解就是,这东西是时代发展的必要,没什么为什么,就是应该学,除非你就是想玩单机,但是就算是单机也会有购买金币之类 ...
- matlab计算相对功率
1.对脑电数据进行db4四层分解,因为脑电频率是在0-64HZ,分层后如图所示, 细节分量[d1 d2 d3 d4] 近似分量[a4] 重建细节分量和近似分量,然后计算对应频段得相对功率谱,重建出来得 ...
- 如何可视化深度学习网络中Attention层
前言 在训练深度学习模型时,常想一窥网络结构中的attention层权重分布,观察序列输入的哪些词或者词组合是网络比较care的.在小论文中主要研究了关于词性POS对输入序列的注意力机制.同时对比实验 ...
- 20200107——记spring的DataSource
spring项目中总要跟数据库打交道,其中怎么连接数据库的方法都有很多,大概分为3类: 1) 通过JNDI获取应用服务器(如JBOSS, Tomcat) 的数据源 2) Spring容器中直接配置数 ...
- 常见web漏洞的整理之SQL注入
SQL注入: 简介: 全称Structured Query Language,即结构化查询语言,是一种特殊的编程语言,用于数据库中的标准数据查询语言.也被作为关系式数据库管理系统的标准语言. 原理: ...
- [YII2] 修改默认控制器Controller以及默认方法Action
试了好多方法都没成功,下面方法绝对能成功设置 在框架里面有源码,在/vendor/yiisoft/yii2/web/Application.php的第34行找到了: class Application ...
- 学习Python爬虫的4幅思维导图
这次给大家带来的是4 幅思维导图,梳理了 Python 爬虫部分核心知识点:网络基础知识,Requests,BeautifulSoup,urllib 和 Scrapy 爬虫框架. 爬虫是一个非常有趣的 ...