问题描述

试题编号:

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. SQL2005清空删除日志

    代码如下: Backup Log DNName with no_log  '这里的DNName是你要收缩的数据库名,自己注意修改下面的数据库名,我就不再注释了.godump transaction D ...

  2. angular1.x + ES6开发风格记录

    angular1.x和ES6开发风格 一.Module ES6有自己的模块机制,所以我们要通过使用ES6的模块机制来淡化ng的框架,使得各业务逻辑层的看不出框架的痕迹,具体的做法是: 把各功能模块的具 ...

  3. sqoop1.4.6配置安装

    1.下载sqoop1.4.6 2.配置环境变量. 3.复制sqoop/conf/sqoop-env-template.sh为sqoop-env.sh 添加相关的配置 #Setpath to where ...

  4. Windows环境下多线程编程原理与应用读书笔记(1)————基本概念

    自从学了操作系统知识后,我就对多线程比较感兴趣,总想让自己写一些有关多线程的程序代码,但一直以来,发现自己都没怎么好好的去全面学习这方面的知识,仅仅是完成了操作系统课程上的小程序,对多线程的理解也不是 ...

  5. 2017广东工业大学程序设计竞赛决赛-tmk买礼物

    tmk买礼物 Description 今天是校赛的日子,为了庆祝这么喜庆的日子,TMK打算买些礼物给女票LSH庆祝一下. TMK进入了雪梨超市,然后刚踏入的一瞬间,店主就对TMK说:“恭喜你成为了本店 ...

  6. GCD Again

    GCD Again Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  7. Mr. Frog’s Game

    Mr. Frog’s Game Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)T ...

  8. 在centos上安装jenkins

    摘要: 本篇介绍了如何在linux服务器上安装jenkins 一:使用war安装 官网地址:https://jenkins.io/doc/ Guided Tour This guided tour w ...

  9. AngularJS学习篇(一)

    AngularJS 使用 表达式 把数据绑定到 HTML. AngularJS 表达式 AngularJS 表达式写在双大括号内:{{ expression }}. AngularJS 表达式把数据绑 ...

  10. C#设计模式之十三代理模式(Proxy)【结构型】

    一.引言   今天我们要讲[结构型]设计模式的第七个模式,也是"结构型"设计模式中的最后一个模式,该模式是[代理模式],英文名称是:Proxy Pattern.还是老套路,先从名字 ...