问题描述

试题编号:

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. 实验之-----------修改oracle实例名

    --查询当前数据库实例名称: SQL> select instance_name,status from v$instance; INSTANCE_NAME STATUS------------ ...

  2. Linux下如何高效删除一个几十G的文本文件的最后一行或几行

    当我们在服务器端记录日志或文本数据时,有时候会有需要删除一个大文件的最后几行,这时如何才能高效实现. 上网浏览终于找到dd命令,亲测如下,删除一个32GB的日志文件最后100行仅需要4分钟 [root ...

  3. 07-从零玩转JavaWeb-对象内存分析

    上篇看了关于数组的内存分析,接下来看一下对象的内存分析 假定有如下类:  第一步会把Person的字节码放到方法区   执行main方法,把main方法的栈帧放到栈当中   Person zly = ...

  4. Leetcode题解(32)

    107. Binary Tree Level Order Traversal II 题目 直接代码: /** * Definition for a binary tree node. * struct ...

  5. HTTP服务简介

    第1章 HTTP服务介绍 1.1 简述用户访网站流程 a 进行域名信息的DNS解析   dig +trace 获得www.oldboyedu.com  ip地址信息 b 进行与网站服务器建立连接,tc ...

  6. 有道云翻译接口 Show类

    package com.yangchong.fanyi; import java.awt.EventQueue;import java.awt.Toolkit; import javax.swing. ...

  7. HTML 3秒一换轮播(鼠标选中旋转停止定时) 动画案例

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. HTML学习笔记 CSS文本及字体及连接及列表(a标签使用及缩进) 案例 第七节 (原创)参考使用表

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. C/C++程序在main之前执行代码

    来源:<周哥教IT.C语言深学活用>https://ke.qq.com/course/242707#tuin=a71606 我们在学习C/C++语言的时候,通常认为main函数是整个程序执 ...

  10. js经典闭包

    setTimeout函数之循环和闭包 前言 之前对于setTimeout的一个经典问题的理解总是感到很迷惑,现在好像清晰一点了,所以把我的理解写下来,我对js的理解也不深入,如果有错误,请务必指出.以 ...