hihoCoder 1367 等式填空
明确题意
等号左边是由'+'和'?'组成的算式,其中处于某个整数(即便这个整数只有一位)首位的'?'可以填入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$ 是等号右边数(和)的位数。
练习题
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 等式填空的更多相关文章
- hihocoder -1121-二分图的判定
hihocoder -1121-二分图的判定 1121 : 二分图一•二分图判定 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 大家好,我是小Hi和小Ho的小伙伴Net ...
- Hihocoder 太阁最新面经算法竞赛18
Hihocoder 太阁最新面经算法竞赛18 source: https://hihocoder.com/contest/hihointerview27/problems 题目1 : Big Plus ...
- hihoCoder太阁最新面经算法竞赛15
hihoCoder太阁最新面经算法竞赛15 Link: http://hihocoder.com/contest/hihointerview24 题目1 : Boarding Passes 时间限制: ...
- 【hihoCoder 1454】【hiho挑战赛25】【坑】Rikka with Tree II
http://hihocoder.com/problemset/problem/1454 调了好长时间,谜之WA... 等我以后学好dp再来看为什么吧,先弃坑(╯‵□′)╯︵┻━┻ #include& ...
- 【hihocoder#1413】Rikka with String 后缀自动机 + 差分
搞了一上午+接近一下午这个题,然后被屠了个稀烂,默默仰慕一晚上学会SAM的以及半天4道SAM的hxy大爷. 题目链接:http://hihocoder.com/problemset/problem/1 ...
- 【hihoCoder】1148:2月29日
问题:http://hihocoder.com/problemset/problem/1148 给定两个日期,计算这两个日期之间有多少个2月29日(包括起始日期). 思路: 1. 将问题转换成求两个日 ...
- 【hihoCoder】1288 : Font Size
题目:http://hihocoder.com/problemset/problem/1288 手机屏幕大小为 W(宽) * H(长),一篇文章有N段,每段有ai个字,要求使得该文章占用的页数不超过P ...
- 【hihoCoder】1082: 然而沼跃鱼早就看穿了一切
题目:http://hihocoder.com/problemset/problem/1082 输入一个字符串,将其中特定的单词替换成另一个单词 代码注意点: 1. getline(istre ...
- 【hihoCoder】1121:二分图一·二分图判定
题目 http://hihocoder.com/problemset/problem/1121 无向图上有N个点,两两之间可以有连线,共有M条连线. 如果对所有点进行涂色(白/黑),判定是否存 ...
随机推荐
- uvm_reg_item——寄存器模型(五)
uvm_reg_item 扩展自uvm_sequence_item,也就说寄存器模型定义了transaction item. adapter 的作用是把这uvm_reg_item转换成uvm_sequ ...
- 包含日志文件getshell
包含日志文件getshell 一.包含日志文件漏洞利用概述 当我们没有上传点,并且也没有url_allow_include功能时,我们就可以考虑包含服务器的日志文件. ...
- codevs 1267 老鼠的旅行 2012年CCC加拿大高中生信息学奥赛
时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description You are a mouse that lives in a cage in ...
- leetcode_1049. Last Stone Weight II_[DP]
1049. Last Stone Weight II https://leetcode.com/problems/last-stone-weight-ii/ 题意:从一堆石头里任选两个石头s1,s2, ...
- js 判断是什么浏览器、是否为谷歌浏览器
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta http ...
- 并查集+思维——X-Plosives
一.问题描述(题目链接) 有n种化合物,每种化合物由两种元素组成.当几种的化合物数量等于他们所含不同元素的数量时,就会发生爆炸.现在依次给出化合物的组成,当新的化合物与之前的化合物放在一起会发生爆炸时 ...
- winhex 中磁盘大小与偏移
下图为c盘(活动分区).上方base offset为相对于整个硬盘的字节偏移量.partition 1中信息包括c盘开始扇区,总扇区数.partition 2 信息为扩展分区开始扇区和扇区数.由 P1 ...
- linux_1
注: 创建软连接: "ln -s xxx 路径1" 在路径1创建xxx的软连接 特点: 1.文件类型 l 2.相当于windows的快捷方式 创建硬链接: "ln xxx ...
- python暴力破解wifi密码程序
import time # 破解wifi库 import pywifi from pywifi import const class PoJie(object): def __init__(self, ...
- Ukulele 天空之城