博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ 1850 Code 数位DP
阅读量:4971 次
发布时间:2019-06-12

本文共 1205 字,大约阅读时间需要 4 分钟。

据说又是一道组合数学题,数学不好的我只想出的DP写法

注意如果输入不合法要输出0

#include 
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;typedef long long LL;const int maxn = 15;int lim[maxn],len;char buf[maxn],str[maxn];LL f[90][90];void getlim(char *str) { memset(lim,0,sizeof(lim)); len = strlen(str); for(int i = 0;i < len;i++) lim[i] = buf[i] - 'a' + 1;}LL dfs(int now,int prev,int bound) { LL &note = f[now][prev == -1 ? 0 : prev]; if(now == len - 1) { if(prev > 0) return 1; return 0; } if(!bound && note != -1) return note; int m = bound ? lim[now + 1] : 26; LL ret = 0; for(int i = prev == -1 ? 0 : prev + 1;i <= m;i++) { ret += dfs(now + 1,i == 0 ? -1 : i,bound && i == lim[now + 1]); } if(!bound) note = ret; return ret;}int main() { while(scanf("%s",buf) != EOF) { bool bad = false; len = strlen(buf); for(int i = 1;i < len;i++) if(buf[i] <= buf[i - 1]) bad = true; if(bad) { puts("0"); continue; } memset(f,-1,sizeof(f)); getlim(buf); cout << dfs(-1,-1,1) << endl; } return 0;}

  

转载于:https://www.cnblogs.com/rolight/p/3886862.html

你可能感兴趣的文章
unity3d 移动与旋转 2
查看>>
寻找二叉查找树中比指定值小的所有节点中最大的那个节点
查看>>
如何设置输入框达到只读效果
查看>>
RT3070 USB WIFI 在连接socket编程过程中问题总结
查看>>
MIS外汇平台荣获“2013年全球最佳STP外汇交易商”
查看>>
LeetCode 题解之Add Digits
查看>>
hdu1502 , Regular Words, dp,高精度加法
查看>>
20120227_CET6
查看>>
SpringBoot在idea中的热部署配置
查看>>
MyEclipse连接SQL Server 2008数据库的操作方法
查看>>
leetcode【67】-Bulb Switcher
查看>>
JS验证图片格式和大小并预览
查看>>
laravel5.2 移植到新服务器上除了“/”路由 ,其它路由对应的页面显示报404错误(Object not found!)———新装的LAMP没有加载Rewrite模块...
查看>>
编写高质量代码--改善python程序的建议(六)
查看>>
windows xp 中的administrator帐户不在用户登录内怎么解决?
查看>>
接口和抽象类有什么区别
查看>>
Codeforces Round #206 (Div. 2)
查看>>
Mycat分表分库
查看>>
模板的文件名和方法名一定要一致!!
查看>>
**p
查看>>