问题描述

试题编号:

201312-4

试题名称:

有趣的数

时间限制:

1.0s

内存限制:

256.0MB

问题描述:

问题描述
  我们把一个数称为有趣的,当且仅当:

  1. 它的数字只包含0, 1, 2, 3,且这四个数字都出现过至少一次。

  2. 所有的0都出现在所有的1之前,而所有的2都出现在所有的3之前。

  3. 最高位数字不为0。

  因此,符合我们定义的最小的有趣的数是2013。除此以外,4位的有趣的数还有两个:2031和2301。

  请计算恰好有n位的有趣的数的个数。由于答案可能非常大,只需要输出答案除以1000000007的余数。
输入格式
  输入只有一行,包括恰好一个正整数n (4 ≤ n ≤ 1000)。
输出格式
  输出只有一行,包括恰好n 位的整数中有趣的数的个数除以1000000007的余数。
样例输入
4
样例输出
3

今天刚注册了,就试着写模拟题。这是第四道,很不错的题目。当时没写出来,只能得0分。网上看了别人的代码后才知道得用DP做,就是状态多一些。
根据题意我们知道,排在第一位的只能是2了。1不可能在第一位,因为所有的0都必须在1的前面,但是0也不能排在第一位,所以就排除了0和1的可能性。又因为所有的2都在3的前面,所以3也不可能排在第一位。于此同时就产生了6种不同的状态,保存在dp数组中。下面详细介绍一下。
(0):第一种状态就是前面几个数字都只是包含数字2,我们记录为dp[i][0]。表示前i位数字的第一种状态。
(1):第二种状态就是前面几个数字只包含有数字2和0,因为0必须在1的前面,所以前i位不会出现2和1的组合。当然,这种状态下没有数字1和3。记录为dp[i][1]。
(2):第三种状态就是前面几个数字只包含有2和3,满足2必须出现在3的前面的情况。没有数字0和1,记录为状态dp[i][2]。
(3):第四种状态就是前面数字只包含数字2、0、1。满足0出现在1的前面。记录为状态dp[i][3]。
(4):第五种状态就是前面数字只包含数字2、0、3。满足2出现在3的前面,记录为状态dp[i][4]。
(5):第六种状态就是0、1、2、3都出现的情况,记录为状态dp[i][5]。
那么,我们可以得到,不论是哪个i的值,都有dp[i][0]=1。因为前面只有数字2,得到唯一的一个数。
而dp[i][1] = (2 * dp[i - 1][1] + dp[i - 1][0] ) 这是因为在前面i-1是第状态2的情况下,第i个数有两种选择,2或者0,所以需要乘2。而当i-1是状态1的时候,i只有一个选择就是0,来保证出现0和2的状态。
同理dp[i][2] = (dp[i - 1][2] + dp[i - 1][0] )这是因为在前面i-1是第3种状态的情况下,第i个数只有一种选择就是数字3,因为2必须出现在3的前面。当前面i-1是第1种状态的时候,也只有一种选择,数字3。这样才能保证是状态3。
接下来dp[i][3] = (2 * dp[i - 1][3] + dp[i - 1][1] )这个也很好理解,就是说在前面i-1是第4种状态的情况下,有1和2两种选择,需要乘2。当时第2种状态的时候,只有一个选择就是1。
下面的情况就不说明了,请广大同志们自行脑补,最后写出来的dp就是6种状态。
最后要用到取模运算的性质,因为这个直接得了好多的0分。
源代码:
#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<string>
#include<string.h>
#include<math.h>
#include<map>
#include<vector>
#include<algorithm>
#include<queue>
using namespace std;
#define MAX 0x3f3f3f3f
#define MIN -0x3f3f3f3f
#define PI 3.14159265358979323
#define N 1005
#define num 1000000007
__int64 dp[1001][6];
int main()
{
int n;
scanf("%d", &n);
int i;
memset(dp, 0, sizeof(dp));
dp[1][0] = 1;
for (i = 2; i <= n; i++)
{
dp[i][0] = 1;
dp[i][1] = (2 * dp[i - 1][1] % num + dp[i - 1][0] % num) % num;
dp[i][2] = (dp[i - 1][2] % num + dp[i - 1][0] % num) % num;
dp[i][3] = (2 * dp[i - 1][3] % num + dp[i - 1][1] % num) % num;
dp[i][4] = ((2 * dp[i - 1][4] % num + dp[i - 1][2] % num) % num + dp[i - 1][1] % num) % num;
dp[i][5] = ((2 * dp[i - 1][5] % num + dp[i - 1][4] % num) % num + dp[i - 1][3] % num) % num;
}
printf("%lld\n", dp[n][5]);
return 0;
}

CCF-201312-4-有趣的数的更多相关文章

  1. CCF CSP 201312-4 有趣的数

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201312-4 有趣的数 问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0 ...

  2. CCF系列之有趣的数(201312-4)

    题目链接: http://115.28.138.223:81/view.page?opid=4 试题名称: 有趣的数 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 我们把一个 ...

  3. CCF模拟题 有趣的数

    有趣的数 时间限制: 1.0s 内存限制: 256.0MB   问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0, 1, 2, 3,且这四个数字都出现过至少一次. 2. 所有的0都 ...

  4. CCF软考---《有趣的数》

    脑子一热报了CCF的软测..但是又觉得好像并没有什么卵用,就当为蓝桥杯预热然后顺便去软件学院玩一玩吧,遇到一个有意思的题: time limits : 1s 问题描述 我们把一个数称为有趣的,当且仅当 ...

  5. CCF 201312-4 有趣的数 (数位DP, 状压DP, 组合数学+暴力枚举, 推公式, 矩阵快速幂)

    问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0, 1, 2, 3,且这四个数字都出现过至少一次. 2. 所有的0都出现在所有的1之前,而所有的2都出现在所有的3之前. 3. 最高 ...

  6. ccf 201312-04 有趣的数(组合数学)

    问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0, 1, 2, 3,且这四个数字都出现过至少一次. 2. 所有的0都出现在所有的1之前,而所有的2都出现在所有的3之前. 3. 最高 ...

  7. CCF 201312-4 有趣的数[dp][难]

    问题描述 试题编号: 201312-4 试题名称: 有趣的数 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0, 1, ...

  8. nyoj 85 有趣的数

    点击打开链接 有趣的数 时间限制:3000 ms  |  内存限制:65535 KB 难度: 描述 把分数按下面的办法排成一个数表. 1/1 1/2 1/3 1/4..... 2/1 2/2 2/3. ...

  9. P2022 有趣的数

    P2022 有趣的数 题目描述 让我们来考虑1到N的正整数集合.让我们把集合中的元素按照字典序排列,例如当N=11时,其顺序应该为:1,10,11,2,3,4,5,6,7,8,9. 定义K在N个数中的 ...

  10. CSP201312-4 有趣的数【dp】

    问题描述 试题编号: 201312-4 试题名称: 有趣的数 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0, 1, ...

随机推荐

  1. 使用angular4和asp.net core 2 web api做个练习项目(一)

    这是一篇学习笔记. angular 5 正式版都快出了, 不过主要是性能升级. 我认为angular 4还是很适合企业的, 就像.net一样. 我用的是windows 10 安装工具: git for ...

  2. 服务端事件EventSource揭秘

    服务端推 服务端推,指的是由服务器主动的向客户端发送消息(响应).在应用层的HTTP协议实现中,"请求-响应"是一个round trip,它的起点来自客户端,因此在应用层之上无法实 ...

  3. SIP简介,第1部分:SIP初探

    说明:以下内容来着之前下载的一份文档,现将概念部分摘录在BLog,完成文档将放在文件中. SIP简介,第1部分:SIP初探 时间:2006-04-07作者:Emmanuel Proulx浏览次数: 2 ...

  4. django 实现同一个ip十分钟内只能注册一次

    很多小伙伴都会有这样的问题,说一个ip地址十分钟内之内注册一次,用来防止用户来重复注册带来不必要的麻烦 逻辑: 取ip,在数据库找ip是否存在,存在判断当前时间和ip上次访问时间之差,小于600不能注 ...

  5. 删除链表中倒数第n个节点

    给定一个链表,删除链表中倒数第n个节点,返回链表的头节点. 样例 给出链表1->2->3->4->5->null和 n = 2. 删除倒数第二个节点之后,这个链表将变成1 ...

  6. 理解Java包

    本质上,包是一个唯一命名的类的集合,将类集合到包里面的主要原因,是为了当在应用程序中使用预先编写的类时避免与类自身可能引起的明明冲突.用于包中的类名不会妨碍另一个包或程序中的类名,因为此时,包中的类名 ...

  7. Android 开发笔记___实战项目:购物车

    购物车的应用很广泛,电商app基本上都有它的身影.由于它用到了多种存储方式,通过项目对数据的存储有更高层次的了解. 1.设计思路 首先看看购物车的外观.第一次进入时里面是空的,去购物页面加入购物车以后 ...

  8. Android 开发笔记___初级控件之实战__计算器

    功能简单,实现并不难,对于初学者可以总和了解初级控件的基本使用. 用到的知识点如下: 线性布局 LinearLayout:整体界面是从上往下的,因此需要垂直方向的linearlayout:下面每行四个 ...

  9. mysql +keeplive+drbd高可用架构

    1MySQL+DRBD+keepalived高可用架构 DRBD(DistributedReplicatedBlockDevice)是一个基于块设备级别在远程服务器直接同步和镜像数据的开源软件,类似于 ...

  10. 兼容IE、火狐、谷歌的页面关闭事件

    <html> <head> <script language="javascript"> var blnCheckUnload = true; ...