秦总

叶粉叶唯叶本命,叶受only

P1149 火柴棒等式

补上之前落下的递归题orz

基本思路就是个二重循环,枚举a,再枚举b,直接a+b得出c

然后在枚举的范围懵了orz,其实最大是24根火柴,减去加号等于号是20根,再减去0后除以2剩余八根,就是最大值为1111

题目描述

给你n根火柴棍,你可以拼出多少个形如“ A+B=C ”的等式?等式中的 A 、 B 、 C 是用火柴棍拼出的整数(若该数非零,则最高位不能是 00 )。用火柴棍拼数字 0-90−9 的拼法如图所示:

注意:

  1. 加号与等号各自需要两根火柴棍

  2. 如果 A≠B ,则 A+B=C与 B+A=C 视为不同的等式( A,B,C>=0 )

  3. nn 根火柴棍必须全部用上

输入输出格式输入格式:

一个整数 n(n<=24)n(n<=24) 。

输出格式:

一个整数,能拼成的不同等式的数目。

输入输出样例

输入样例#1: 14

输出样例#1: 2

输入样例#2: 18

输出样例#2: 9

说明

【输入输出样例1解释】

2 个等式为

 0+1=1

0+1=1  。

【输入输出样例2解释】

99 个等式为:

0+4=4

0+11=11

1+10=11

2+2=4

2+7=9

4+0=4

7+2=9

10+1=11

11+0=11

ac代码:

#include <iostream>

#include <cmath>

#include <map>

#define ll long long

using namespace std;


int s=0;

int n;

void dfs(int x,int l,int t){

int i;

map <int,int> mp;

mp[0]=6,mp[1]=2,mp[3]=5,mp[4]=4,mp[5]=5,mp[6]=6,mp[7]=3,mp[8]=7,mp[9]=6,mp[2]=5;

int r=l;

for(i=0;i<=t;i++){

l=r;

int y=i;

do{

int k=y%10;

l+=mp[k];

y=y/10;

}while(y);


int h=i+x;

if(l>=n) continue;


int e=h;

do{

int k=h%10;

l+=mp[k];

h=h/10;


}while(h);


if(l==n){

s++;


}


}

}

int main()

{


cin>>n;

map <int,int> mp;

mp[0]=6,mp[1]=2,mp[2]=5,mp[3]=5,mp[4]=4,mp[5]=5,mp[6]=6,mp[7]=3,mp[8]=7,mp[9]=6;

n-=4;//等号和加号

int sum=0,i;//方法总数 

ll t=0;

int g=(n-6)/4;

while(g>0){

t=t*10+1;

g--;

}

t=1200;

for(i=0;i<=t;i++){

g=0;//已用火柴 

int h=i;

do{

int k=h%10;

g+=mp[k];

h=h/10;

}while(h);

    if(g>=n) continue;

dfs(i,g,t);


}

cout<<s<<endl;

return 0;

}


评论