明确题意

等号左边是由'+'和'?'组成的算式,其中处于某个整数(即便这个整数只有一位)首位的'?'可以填入1-9中的某个数字,其余'?'可以填入0-9中的某个数字。

SOURCE

这里未明确等号左边有几个整数(至少有一个)。读题时我未能仔细理解这句话的含义,根据样例误认为有且仅有两个整数相加。另外,等号右边的非负整数,题目虽未明确是否有前导零,可以认为没有(不应该在这里纠结题意)。

做题的第一步是读题,诚哉斯言!

解法

数位DP。

将等号右边的非负整数的数位,按从低位到高位的顺序从1开始编号。

$dp[i][j]$:满足前 $i$ 位且对第 $i+1$ 位的进位是 $j$ 的方案数

$n$ 个正整数相加, 每一位向前一位的进位都小于 $n$

状态转移便转化成了组合计数问题。

将 $n$ 个相同的球放进 $m$ 个不同的盒子里,每个盒子里最多放 $9$ 个球。在这 $n$ 个盒子中指定 $k$ 个,其中每个盒子里至少放一个球。求方案数。

由于放进的球数有上限,并不能用挡板法

做法:枚举分配到 $k$ 个非空盒子的球的总数,分别计算两类盒子的放置方案数,这两个计数问题都可采用简单的DP解决。

总复杂度:$O(n2+mn3)$,$n$ 是等号左边的数(加数)的个数,$m$ 是等号右边数(和)的位数。

练习题

hihoCoder 1076 与链

Implementation

#include <bits/stdc++.h>
using namespace std; const int N=105; long long dp[N][50];
const int mod=1e9+7; char s[N];
int c[2][50][500]; void prep(int n)
{
c[1][0][0]=c[0][0][0]=1; for(int i=1; i<=n; i++)
{
for(int j=i; j<=9*i; j++)
{
for(int k=1; k<=min(9, j-i+1); k++)
{
c[1][i][j]+=c[1][i-1][j-k], c[1][i][j]%=mod;
}
} for(int j=0; j<=9*i; j++)
{
for(int k=0; k<=min(9, j); k++)
{
c[0][i][j]+=c[0][i-1][j-k], c[0][i][j]%=mod;
}
}
}
} vector<int> a; int main()
{ int ma=0; for(; ; )
{
int len;
scanf("%*[?]%n%[=+]", &len, s);
a.push_back(len);
ma=max(ma, len);
if(s[0]=='=')
{
break;
}
} int n;
scanf("%s%n", s+1, &n); if(n<ma)
{
puts("0");
return 0;
} prep(a.size()); reverse(s+1, s+n+1); dp[0][0]=1;
int carry=a.size(); for(int i=1; i<=n; i++)
{
int cnt1=0, cnt2=0;
for(auto x: a)
{
cnt1+=x==i;
cnt2+=x>i;
} for(int j=0; j<carry; j++)
for(int k=0; k<carry; k++)
{
int tot=s[i]-'0'+10*j-k;
long long sum=0;
for(int l=cnt1; l<=tot; l++)
{
sum+=(long long)c[1][cnt1][l]*c[0][cnt2][tot-l];
sum%=mod;
}
dp[i][j]+=dp[i-1][k]*sum;
dp[i][j]%=mod;
}
} cout<<dp[n][0]<<endl; return 0;
}

hihoCoder 1367 等式填空的更多相关文章

  1. hihocoder -1121-二分图的判定

    hihocoder -1121-二分图的判定 1121 : 二分图一•二分图判定 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 大家好,我是小Hi和小Ho的小伙伴Net ...

  2. Hihocoder 太阁最新面经算法竞赛18

    Hihocoder 太阁最新面经算法竞赛18 source: https://hihocoder.com/contest/hihointerview27/problems 题目1 : Big Plus ...

  3. hihoCoder太阁最新面经算法竞赛15

    hihoCoder太阁最新面经算法竞赛15 Link: http://hihocoder.com/contest/hihointerview24 题目1 : Boarding Passes 时间限制: ...

  4. 【hihoCoder 1454】【hiho挑战赛25】【坑】Rikka with Tree II

    http://hihocoder.com/problemset/problem/1454 调了好长时间,谜之WA... 等我以后学好dp再来看为什么吧,先弃坑(╯‵□′)╯︵┻━┻ #include& ...

  5. 【hihocoder#1413】Rikka with String 后缀自动机 + 差分

    搞了一上午+接近一下午这个题,然后被屠了个稀烂,默默仰慕一晚上学会SAM的以及半天4道SAM的hxy大爷. 题目链接:http://hihocoder.com/problemset/problem/1 ...

  6. 【hihoCoder】1148:2月29日

    问题:http://hihocoder.com/problemset/problem/1148 给定两个日期,计算这两个日期之间有多少个2月29日(包括起始日期). 思路: 1. 将问题转换成求两个日 ...

  7. 【hihoCoder】1288 : Font Size

    题目:http://hihocoder.com/problemset/problem/1288 手机屏幕大小为 W(宽) * H(长),一篇文章有N段,每段有ai个字,要求使得该文章占用的页数不超过P ...

  8. 【hihoCoder】1082: 然而沼跃鱼早就看穿了一切

      题目:http://hihocoder.com/problemset/problem/1082 输入一个字符串,将其中特定的单词替换成另一个单词   代码注意点: 1. getline(istre ...

  9. 【hihoCoder】1121:二分图一·二分图判定

      题目   http://hihocoder.com/problemset/problem/1121 无向图上有N个点,两两之间可以有连线,共有M条连线. 如果对所有点进行涂色(白/黑),判定是否存 ...

随机推荐

  1. bmp图像文件格式说明

    bmp图片文件包含4个部分数据,位图文件头,位图信息头,颜色表和位图数据(即RGB值). 在看位图格式之前先看一个问题,如果每个像素都用前面的24位色去表示,那么一个像素值需要3个字节数据,24位色也 ...

  2. MySQL流程控制和存储过程介绍

    /*定义变量方式1:set @变量名=值;方式2:select 值 into @变量名;方式3:declare 变量名 类型(字符串类型加范围) default 值; in参数 入参的值会仅在存储过程 ...

  3. ios UI自动化测试

    转载:http://www.cnblogs.com/dokaygang128/p/3517674.html 一.一些注意事项: 1.做自动化测试时注意如果是真机话首先要设置不锁屏. 2.自动化测试过程 ...

  4. 使用vue做移动端瀑布流分页

    讲到瀑布流分页有一个方法一定是要用到的 pullToRefresh() 这个也没什么好解释的,想了解的可以去百度一下 下面上代码 <div id="main" class=& ...

  5. abp viewmodel的写法

    我的写法 public class QuotaCreateOrEditViewModel { public QuotaDto LoanQuota { get; set; } public bool I ...

  6. 参考别人的代码写的aes加密,记录一下(AES,ECB模式,填充PKCS5Padding,数据块128位,偏移量无,以hex16进制输出)

    package org.jimmy.autosearch2019.test; import java.security.SecureRandom; import javax.crypto.Cipher ...

  7. Python IDE推荐

    八个最佳Python IDE 作者:chszs,转载需注明.博客主页:http://blog.csdn.net/chszs Python是一种功能强大.语言简洁的编程语言.本文向大家推荐8个适合pyt ...

  8. MySql的基操勿六

    2018/12/6 星期四 19:34:07 authot by dabaine 数据库注释; -- 这就是注释 /*.....*/ 这也是注释 创建库; create databse [if not ...

  9. mybatis 批量操作增删改查

    在介绍批量操作之前,首先先介绍一个语法:foreach.可以说是,foreach是整个批量操作的灵魂. 属性 描述 item 循环体中的具体对象. 支持属性的点路径访问,如item.age,item. ...

  10. 蓝牙学习 (8)配对raspberryPi和SensorTag CC2650

    在上一篇中,用raspberryPi能够扫描到Ti SensorTag. 但是没有获得更多的数据,并且发现sensor Tag并没有回复scan request. https://blog.csdn. ...