题意:

  给你三个数A, B, C(没有前导0),但是其中某些位不知道。 问A+B=C成立有多少种情况。

思路:

  从最后一位往前推,枚举A, B的每一种情况,考虑进位和不进位两种情况。

代码:

 #include <cstdio>
#include <cstring>
#include <algorithm> using namespace std; typedef long long ll; const ll MOD = (ll)1e9+;
const int MAXN = ; ll dp[MAXN][];
char str[][MAXN]; int main() {
#ifdef Phantom01
freopen("CSU1374.txt", "r", stdin);
#endif // Phantom01 while (scanf("%s", str[])!=EOF) {
if (''==str[][]&&'\0'==str[][]) return ;
scanf("%s%s", str[], str[]);
memset(dp, , sizeof(dp));
int len = strlen(str[]);
dp[len][] = ;
for (int l = len-; l > ; l--) //第l位
for (int p = ; p < ; p++) if (dp[l+][p]>) //进位
for (int i = ; i < ; i++) if ('?'==str[][l] || i==(str[][l]-'')) //a[l]
for (int j = ; j < ; j++) if ('?'==str[][l] || j==(str[][l]-'')) //b[l]
if ('?'==str[][l] || (i+j+p)%==(str[][l]-'')) {
ll &now = dp[l][(i+j+p)/];
now = (now+dp[l+][p])%MOD;
}
//最后一位不为0
for (int p = ; p < ; p++) if (dp[][p]>) //进位
for (int i = ; i < ; i++) if ('?'==str[][] || i==(str[][]-'')) //a[l]
for (int j = ; j < ; j++) if ('?'==str[][] || j==(str[][]-'')) //b[l]
if ('?'==str[][] || (i+j+p)%==(str[][]-'')) {
ll &now = dp[][(i+j+p)/];
now = (now+dp[][p])%MOD;
} printf("%lld\n", dp[][]);
}
}

CSU 1374

CSU 1374 Restore Calculation 数位DP的更多相关文章

  1. 【BZOJ1662】[Usaco2006 Nov]Round Numbers 圆环数 数位DP

    [BZOJ1662][Usaco2006 Nov]Round Numbers 圆环数 Description 正如你所知,奶牛们没有手指以至于不能玩"石头剪刀布"来任意地决定例如谁 ...

  2. bzoj1026数位dp

    基础的数位dp 但是ce了一发,(abs难道不是cmath里的吗?改成bits/stdc++.h就过了) #include <bits/stdc++.h> using namespace ...

  3. uva12063数位dp

    辣鸡军训毁我青春!!! 因为在军训,导致很长时间都只能看书yy题目,而不能溜到机房鏼题 于是在猫大的帮助下我发现这道习题是数位dp 然后想起之前讲dp的时候一直在补作业所以没怎么写,然后就试了试 果然 ...

  4. HDU2089 不要62[数位DP]

    不要62 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  5. 数位DP GYM 100827 E Hill Number

    题目链接 题意:判断小于n的数字中,数位从高到低成上升再下降的趋势的数字的个数 分析:简单的数位DP,保存前一位的数字,注意临界点的处理,都是套路. #include <bits/stdc++. ...

  6. 数位dp总结

    由简单到稍微难点. 从网上搜了10到数位dp的题目,有几道还是很难想到的,前几道基本都是模板题,供入门用. 点开即可看题解. hdu3555 Bomb hdu3652 B-number hdu2089 ...

  7. 数位DP入门

    HDU 2089 不要62 DESC: 问l, r范围内的没有4和相邻62的数有多少个. #include <stdio.h> #include <string.h> #inc ...

  8. 数位DP之奥义

    恩是的没错数位DP的奥义就是一个简练的dfs模板 int dfs(int position, int condition, bool boundary) { ) return (condition ? ...

  9. 浅谈数位DP

    在了解数位dp之前,先来看一个问题: 例1.求a~b中不包含49的数的个数. 0 < a.b < 2*10^9 注意到n的数据范围非常大,暴力求解是不可能的,考虑dp,如果直接记录下数字, ...

随机推荐

  1. Windows phone解决GB2312编码问题

    环境win8+vse for Windows phone 在网站http://encoding4silverlight.codeplex.com/上点击下载 之后有三个文件big5.bin,DBCSE ...

  2. Android Handling back press when using fragments in Android

    In MainActivity: getSupportFragmentManager().beginTransaction().replace(R.id.gif_contents, gifPageTw ...

  3. JavaScript学习——使用JS完成全选和全不选操作

    1.我们希望在后台系统实现一个批量删除的操作(全选所有的复选框)和全不选,显示效果如下: 2.步骤分析: 第一步:确定事件(onclick)并为其绑定一个函数(事件绑定到编号前面的复选框里面) 第二步 ...

  4. 配置 centos apache 的日志文件为每天保存,在home分区

    /usr/local/apache/bin/rotatelogs 这个执行程序会根据安装方式不同的位置也不同,yum安装的话,路径为:/usr/sbin/rotatelogs 改为: ErrorLog ...

  5. H5中嵌入flash

    <object height="900px" width="100%" classid="clsid:D27CDB6E-AE6D-11cf-96 ...

  6. 我的Java历程_写出这个数

    lzJava基础进行中,今天偶然间看到的一个题目: 读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字.如下代码: import java.util.*;public class Ma ...

  7. 路飞学城Python-Day15(模块二思维导图)

  8. Spring jar包功能

    1.spring.jar 是包含有完整发布模块的单个jar 包. 2. org.springframework.aop 包含在应用中使用Spring的AOP特性时所需的类. 3. org.spring ...

  9. win10安装node/yarn报错2503/2502

    当我们从node官网下载windows安装包时会得到一个msi文件,由于win10的安全策略比较严格,所以我们在右键菜单上找不到以管理员运行这个按钮: 普通的exe文件: msi文件: 解决办法: 此 ...

  10. 注解形式读取properties文件中的属性

    1.spring.xml中加入(多个properties 用逗号隔开)  <context:property-placeholder location="classpath:jdbc. ...