明确题意

等号左边是由'+'和'?'组成的算式,其中处于某个整数(即便这个整数只有一位)首位的'?'可以填入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. uvm_scoreboard——得分

    scoreboard 是验证平台很重要的一部分,因为,验证就是给激励,然后,检查结果.而scoreboard 就是肩负这检查结果的重任.测试用例能不能过,全由scoreboard说了算. A scor ...

  2. (转)VIM 一键自动添加文件头注释

    通过修改VIM的配置文件.vimrc可以让Vim(gvim)支持自动添加作者信息,具体代码如下: "进行版权声明的设置 "添加或更新头 map <F4> :call T ...

  3. C++拾遗(二)——初窥标准库类型

    本篇博文的开始,先介绍一道书上看到的智力题:有20瓶药丸,其中19瓶装有1克/粒的药丸,余下一瓶装有1.1克/粒的药丸.有一台称重精准的天平,只是用一次天平的情况下如何找出比较重的那瓶药丸? 好了,直 ...

  4. 修改完linux bashrc文件之后,如何不重启系统使其生效

    修改完后,输入如下命令即可 ##@##:~/    source ~/.bashrc 之后bashrc文件就可以使用! 注: 使用ssh登陆shell的时候,系统不会自动调用.bashrc文件, 只是 ...

  5. Cannot fetch index base URL https://pypi.python.org/pypi/ 解决方法

    vi /etc/resolv.conf # Dynamic resolv.conf(5) file for glibc resolver(3) generated by resolvconf(8) # ...

  6. 快速WCF

    初级原理:通得过地址调用接口服务,接口服务调用对应实现方法 援引文章地址:http://www.cnblogs.com/iamlilinfeng/archive/2012/09/25/2700049. ...

  7. spring (由Rod Johnson创建的一个开源框架)

    你可能正在想“Spring不过是另外一个的framework”.当已经有许多开放源代码(和专有)J2EEframework时,我们为什么还需要Spring Framework? Spring是独特的, ...

  8. go语音实战读后感——一

    1.第一个go程序: package main import ( "fmt" ) func main() { fmt.Println("Hello go") } ...

  9. maven项目在myeclipse中不出现Maven Dependencies 和maven标识的解决方法

    这种情况通常出现在 我们新加载了一个 maven的项目,但是myeclipse没识别到. 或者说 我们把该项目修改成了maven项目--------也就是说该项目 有了pom.xml 但是还没有mav ...

  10. SpringMVC+Spring+Mybatis整合程序之整合

    因为每个人思路不一样,所以我在这边先分享自己的思路对于mybatis开发持久层(DAO:DataBase Access Object 持久层访问对象)有两种.第一种:传统的开发持久层方式即需要程序员开 ...