B - 秋实大哥掰手指

Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 2048/1024KB (Java/Others)
Submit Status

秋实大哥发现数据结构专题出到了N题,但是他一时算不出来已经有了几道题,他就萌萌地掰手指数。 这个时候他发现,虽然人们根据手指数创造了十进制数,但是两只手同时能表达的数是0-10一共十一个数字。 这样,他觉得如果用手指表现十进制数,同一个十进制数就会有很多种不同的表现方法。 比如,110这样一个十进制数,就有110(1*100+1*10+0*1),AA(10*10+10*1 )和10A(1*100+0*10+10*1)三种表示方法(A表示伸出十根手指)。

现在给你一些十进制数,聪明的你能不能计算出按照秋实大哥的方法,每个数能有多少种表现方式(方案数对1000000007取模)。

Input

只有一组数据,第一行一个数字n,表示人赢给出的数字的长度。 第二行一个整数a(1<=a<=1e1000000),表示给出的十进制数。

Output

对于每组数据输出一个整数,表示输入的数人赢有多少种表示方法(结果可能很大,取模1000000007的余数)。

Sample input and output

Sample Input Sample Output
1
1
1
3
110
3
6
100100
11

Hint

注意内存~~ 怎么处理课上会讲呀~~

解题报告:

根据题目条件,我们不难想到上一位最多只能缺 10 (即在上一位摆的数比规定数字少 1 ),那么我们可以设计这样的状态:

F( i , 0 )  表示第 i 位为止,不缺 10 的方案数.

F( i , 1 )  表示第 i 位为止,缺 10 的方案数.

如何转移呢?

我们先假设当前正在转移第 i 位,且第 i 位的数字为 Number.

显然有

f( i , 0 )  += f( i – 1 , 0 ) ; //上一位就不缺,这一位也不缺,正常摆.

If (Number == 0)

f( i , 0 )  += f( i – 1 , 1 ) ;  //上一位缺了 10 ,这位恰好是 0 ,补上.

f( i , 1 )  += f( i – 1 , 1 ) ;  //上一直缺了 10 ,这次不妨摆 9 ,转移到下一位依然缺 10

else if (Number == 1)

f( i , 1 )  += f( i – 1 , 1 )  //这一位需要 11 ,摆 10 ,转移到下一位依然缺 10

f( i , 1 )  += f( i – 1 , 0 )  //上一位不缺,这一位摆的数少 1 ,转移到下一位缺 10

else

f( i , 1 )  += f( i – 1 , 0 )  //上一位不缺,这一位摆的数少 1 ,转移到下一位缺 10

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <stdbool.h>
typedef long long ll;
ll mod = ;
ll f[][];
/*
0 到上次为止,不缺
1 到上次为止,缺10
*/
int cur = ;
void init_()
{
int i;
for(i = ; i <= ; ++ i)
f[cur][i] = ;
} int main(int argc,char *argv[])
{
int n,i,j,c,k;
scanf("%d",&n);
char ch;
while()
{
ch = getchar();
if (ch == '\n')
break;
}
memset(f,,sizeof(f));
//
ch = getchar();
int num = ch - '';
f[cur][] = ;
if (num != )
f[cur][] = ;
//
for(i = ; i < n ; ++ i)
{
cur ^= ;
init_();
ch = getchar();
int num = ch - '';
f[cur][] = (f[cur][] % mod+ f[cur^][] % mod ) % mod;
if (num == )
{
f[cur][] = (f[cur][] % mod+ f[cur^][] % mod) % mod;
f[cur][] = (f[cur][] % mod+ f[cur^][] % mod) % mod;
}
else if(num == )
{
f[cur][] = (f[cur][] % mod + f[cur^][] % mod ) % mod;
f[cur][] = (f[cur][] % mod + f[cur^][] % mod) % mod;
}
else
{
f[cur][] = (f[cur][] % mod + f[cur^][] % mod ) % mod;
}
}
printf("%lld\n",f[cur][] % mod);
return ;
}

UESTC_秋实大哥掰手指 2015 UESTC Training for Dynamic Programming<Problem B>的更多相关文章

  1. UESTC_秋实大哥搞算数 2015 UESTC Training for Data Structures<Problem N>

    N - 秋实大哥搞算数 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Subm ...

  2. UESTC_秋实大哥打游戏 2015 UESTC Training for Data Structures<Problem H>

    H - 秋实大哥打游戏 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Subm ...

  3. UESTC_秋实大哥去打工 2015 UESTC Training for Data Structures<Problem G>

    G - 秋实大哥去打工 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Subm ...

  4. UESTC_秋实大哥与家 2015 UESTC Training for Data Structures<Problem E>

    E - 秋实大哥与家 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submi ...

  5. UESTC_秋实大哥与战争 2015 UESTC Training for Data Structures<Problem D>

    D - 秋实大哥与战争 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Subm ...

  6. UESTC_秋实大哥与快餐店 2015 UESTC Training for Data Structures<Problem C>

    C - 秋实大哥与快餐店 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Sub ...

  7. UESTC_秋实大哥与花 2015 UESTC Training for Data Structures<Problem B>

    B - 秋实大哥与花 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submi ...

  8. UESTC_秋实大哥与小朋友 2015 UESTC Training for Data Structures<Problem A>

    A - 秋实大哥与小朋友 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Sub ...

  9. UESTC_邱老师选妹子(二) 2015 UESTC Training for Dynamic Programming<Problem I>

    I - 邱老师选妹子(二) Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Su ...

随机推荐

  1. win环境下mysql5.6.14的所有变量的默认值

    在windows mysql5.6.14 x64版本下my.ini如下: [mysqld] port  = 3306 socket  = /tmp/mysql.sock basedir=D:/wamp ...

  2. 国内ip信息库的组建

    1.从 APNIC 分析得到国内的段 数据源位置:http://ftp.apnic.net/apnic/stats/apnic/delegated-apnic-latest 2.从QQ纯真库分析得到国 ...

  3. [Spring入门学习笔记][创建网站URL]

    设计网站的URL 现代的Web站点都会设计一套拥有明确意义,方便用户记忆的URL,不论是域名还是路径,以天码营为例: http://tianmaying.com/courses表示网站下所有的课程列表 ...

  4. 关于object在使用上的问题

    关于object在使用上的问题 1.直接调用标签<object>中的单击事件 <object>是含有onclick和ondblclick两个事件的.按照以往方式,直接在里面调用 ...

  5. .Net Memory -- Windbg基本命令

    命令 解释 .cls 清空命令窗口屏幕 .load dllfullpath 加载debugger扩展dll如SOS sosex psscor. .loadby dll moduleName 加载deb ...

  6. [转]PictureEx.h和PictureEx.cpp源文件

    要显示一个gif,网上找了个,子类化了MFCl图片控件,用着方便,记一下 转自:http://www.bccn.net/Article/net/vcnet/jszl/200709/6386.html ...

  7. java学会需要掌握的知识(来源网上。。)

    Java就业指导 2016-03-22 骆昊 程序人生 点击上方"程序人生"关注我们 想要成为合格的Java程序员或工程师到底需要具备哪些专业技能,面试者在面试之前到底需要准备哪些 ...

  8. mysql实现随机查询

    一.随机查询一条数据 方法一:SELECT * FROM `table` ORDER BY RAND() limit 1 评价:不建议使用,效率非常低,官方文档中进行说明:Order By和RAND( ...

  9. 不用不知道 apply()与call()的强大

    在看关于javascript继承的时候 好多地方都用到了apply()和call() 之前在简单编程的时候根本没有遇到过 查阅资料后才发现这两个方法是如此的好用. 下面从几方面来看一下这两个方法: 1 ...

  10. 基于VMware的eCos环境编译redboot(脚本配置redboot)

    基于VMware的ecos,redboot及hello world(1)安装请参照[[ecos学习2]wmware运行redboot[方法二]--图形实现配置 ] (2)修改内存布局文件:~/i386 ...