问题描述:

试题编号: 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

题目大意:

解题思路:

附录:

(审题过程)

读题后10min之内一度以为是不是题目不严谨,n位是不是都是一样的,比如1个0,2个1,2个2,1个3组成多少种有趣数?再一想不对,应该是用递归的角度来思考,n位的话,遍历第一位是什么,第二位什么......即可以混合。

递归所求(题目答案)为全集,而无数种相同n位有趣数为字集

(写代码过程)

第一次运行

 1 //dfs(x){for(0 n)for(0 4)}
2 //
3 //dfs(x, n)
4 //
5 //fx(x)for(0 n)for(0 4)
6 //纸
7 //养成好习惯,先想再码
8 #include<cstdio>
9 int n;
10 void dfs(bool canbe_1, bool canbe_3, int No);//No表示该在哪个位置填入数字,从0开始
11 char number[1050];
12 char box[4] = {0, 1, 2, 3};//填入什么数字从这四个中选
13 int answer;
14 int main()
15 {
16 scanf("%d", &n);
17 dfs(0, 0, 0);
18 // printf("%d%1000000007", answer);
19 printf("%d", answer);
20 }
21 void dfs(bool canbe___1, bool canbe___3, int No)
22 {
23 if(No == n + 1){
24 answer ++;
25 return;
26 }
27 for(int i = 0; i < 4; i ++)
28 {
29 // if()//这里是先判断No还是先判断i
30 if(i == 0){
31 if(No == 0)
32 continue;
33 else{
34 number[No] = box[i];
35 canbe___1 = 1;
36 dfs(canbe___1, canbe___3, No ++);
37 }
38 }
39 else if(i == 1){
40 if(!canbe___1)
41 continue;
42 else{
43 number[No] = box[i];
44 dfs(canbe___1, canbe___3, No ++);
45 }
46 }
47 else if(i == 2){
48 number[No] = box[i];
49 canbe___3 = 1;
50 dfs(canbe___1, canbe___3, No ++);
51 }
52 else if(i == 3){
53 if(!canbe___3)
54 continue;
55 else{
56 number[No] = box[i];
57 dfs(canbe___1, canbe___3, No ++);
58 }
59 }
60 }
61 }
62
63 //No. !=0
64 //0 1
65 //2 3
66 //
67 //2013
68 //2031
69 //2301
70 //
71 //0 0123
72 //1 0123
73 //2 0123
74 //3 0123

第二次运行

 1 #include<cstdio>
2 int n;
3 void dfs(bool canbe_1, bool canbe_3, int No);//No表示该在哪个位置填入数字,从0开始
4 char number[1050];
5 char box[4] = {0, 1, 2, 3};//填入什么数字从这四个中选
6 int answer;
7 int main()
8 {
9 scanf("%d", &n);
10 dfs(0, 0, 0);
11 printf("%d", answer);
12 }
13 void dfs(bool canbe___1, bool canbe___3, int No)
14 {
15 if(No == n){
16 answer ++;
17 return;
18 }
19 for(int i = 0; i < 4; i ++){
20 // if()//这里是先判断No还是先判断i
21 if(i == 0){
22 if(No == 0)
23 continue;
24 else{
25 number[No] = box[i];
26 canbe___1 = 1;
27 dfs(canbe___1, canbe___3, No ++);
28 }
29 }
30 else if(i == 1){
31 if(!canbe___1)
32 continue;
33 else{
34 number[No] = box[i];
35 dfs(canbe___1, canbe___3, No ++);
36 }
37 }
38 else if(i == 2){
39 printf("##");
40 number[No] = box[i];
41 canbe___3 = 1;
42 dfs(canbe___1, canbe___3, No ++);
43 }
44 else if(i == 3){
45 if(!canbe___3)
46 continue;
47 else{
48 number[No] = box[i];
49 dfs(canbe___1, canbe___3, No ++);
50 }
51 }
52 }
53 }
54
55 //0 1
56 //2 3
57
58 //2013
59 //2031
60 //2301
61
62 dfs 011
63 2
64 20
65 dfs 112
66 200
67
68 //这四个数字都出现过至少一次
69 20133//先0123再重复
70 20013//直接前四位中就有重复
71
72 //卡住了。“这四个数字都出现过至少一次”,不知道怎么写。
73
74 2 _ _ _ _ _
75 3
76 //排列组合?

数位DP,

我以为0出现过就可以出现1呢。即010可以,其实错误。

(扩展)

没太搞明白,时间,内存限制,打acm装逼时只知道1s是10^7左右 当代计算机1s计算达百万次

 

CCF 有趣的数的更多相关文章

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

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

  2. CCF CSP 201312-4 有趣的数

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

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

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

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

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

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

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

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

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

  7. CCF模拟题 有趣的数

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

  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. 搭建k8s集群完整版本

    搭建k8s集群完整版 基础设置 设置主机ip nmcli con add ifname ens33 con-name ens33 autoconnect yes type ethernet nmcli ...

  2. 使用优启通 制作 WIN PE U盘时报BOOT.WIM 有毒的解决方法

    使用优启通 制作 WIN PE U盘时报BOOT.WIM 有毒的解决方法 1.打开"Windows Defender". 2.点击"病毒和威胁防护". 3.点击 ...

  3. Semantic Kernel入门系列:通过依赖注入管理对象和插件

    前言 本章讲一下在Semantic Kernel中使用DependencyInject(依赖注入),在之前的章节我们都是通过手动创建Kernel对象来完成框架的初始化工作,今天我们用依赖注入的方式来实 ...

  4. FlashDuty Changelog 2023-09-21 | 自定义字段和开发者中心

    FlashDuty:一站式告警响应平台,前往此地址免费体验! 自定义字段 FlashDuty 已支持接入大部分常见的告警系统,我们将推送内容中的大部分信息放到了 Lables 进行展示.尽管如此,我们 ...

  5. OAuth + Security - 错误收集

    Could not decode JSON for additional information: BaseClientDetails 完整的错误输出如下: 2019-12-03 22:18:37.2 ...

  6. Imdeploy笔记

    Smiling & Weeping ---- 天气不好的时候,我会小心地把自己心上的裂缝补起来.为什么?... LMDeploy 的量化和部署 1 环境配置 2 服务部署 2.1 模型转换 2 ...

  7. 第一篇Scrum冲刺博客--原班人马打造队

    0 项目地址 点此进入 1 第一次开会/任务认领 1.1 第一次例会(2024.4.27) 第一次开会照片记录 1.2 开发认领 在查看老师在实验报告中学长的博客给了我一定的启发,我在腾讯表格中创建了 ...

  8. 链表中,LNode和* LinkList的理解

    typedef struct LNode { int data; struct LNode* next; }LNode, * LinkList; 这是标准链表创建法. 简单的说,其中LNode和 * ...

  9. R语言求取大量遥感影像的平均值、标准差:raster库

      本文介绍基于R语言中的raster包,批量读取多张栅格图像,对多个栅格图像计算平均值.标准差,并将所得新的栅格结果图像保存的方法.   在文章基于R语言的raster包读取遥感影像中,我们介绍了基 ...

  10. 三种方法教你下载 Windows 10 和 Windows 11 原生镜像

    原文地址:https://itxiaozhang.com/three-methods-to-download-windows-10-and-windows-11-iso/ 本文配合视频食用效果最佳,视 ...