CCF 有趣的数
问题描述:
| 试题编号: | 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 有趣的数的更多相关文章
- CCF软考---《有趣的数》
脑子一热报了CCF的软测..但是又觉得好像并没有什么卵用,就当为蓝桥杯预热然后顺便去软件学院玩一玩吧,遇到一个有意思的题: time limits : 1s 问题描述 我们把一个数称为有趣的,当且仅当 ...
- CCF CSP 201312-4 有趣的数
CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201312-4 有趣的数 问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0 ...
- CCF 201312-4 有趣的数 (数位DP, 状压DP, 组合数学+暴力枚举, 推公式, 矩阵快速幂)
问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0, 1, 2, 3,且这四个数字都出现过至少一次. 2. 所有的0都出现在所有的1之前,而所有的2都出现在所有的3之前. 3. 最高 ...
- CCF系列之有趣的数(201312-4)
题目链接: http://115.28.138.223:81/view.page?opid=4 试题名称: 有趣的数 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 我们把一个 ...
- ccf 201312-04 有趣的数(组合数学)
问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0, 1, 2, 3,且这四个数字都出现过至少一次. 2. 所有的0都出现在所有的1之前,而所有的2都出现在所有的3之前. 3. 最高 ...
- CCF 201312-4 有趣的数[dp][难]
问题描述 试题编号: 201312-4 试题名称: 有趣的数 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0, 1, ...
- CCF模拟题 有趣的数
有趣的数 时间限制: 1.0s 内存限制: 256.0MB 问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0, 1, 2, 3,且这四个数字都出现过至少一次. 2. 所有的0都 ...
- nyoj 85 有趣的数
点击打开链接 有趣的数 时间限制:3000 ms | 内存限制:65535 KB 难度: 描述 把分数按下面的办法排成一个数表. 1/1 1/2 1/3 1/4..... 2/1 2/2 2/3. ...
- P2022 有趣的数
P2022 有趣的数 题目描述 让我们来考虑1到N的正整数集合.让我们把集合中的元素按照字典序排列,例如当N=11时,其顺序应该为:1,10,11,2,3,4,5,6,7,8,9. 定义K在N个数中的 ...
- CSP201312-4 有趣的数【dp】
问题描述 试题编号: 201312-4 试题名称: 有趣的数 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0, 1, ...
随机推荐
- Android 12(S) Binder(一)
今天开始了解一下binder,就先从ServiceManager开始学习. 网上的相关博文普遍是Android 11之前的,阅读时对比Android 11或12的代码发现有很多内容找不到了,比如 fr ...
- Jenkins获取gitlab源代码
Jenkins获取gitlab源代码 Jenkins权限获取 在日常工作做由于Jenkins启动用户是Jenkins,在执行脚本时系统命令是无法让Jenkins执行的,如果需要Jenkins权限有两种 ...
- FLV 分析脚本
一.需求 通过脚本,可以检查本地flv文件格式是否正确,可以打印每个Tag中的二进制内容 二.效果 可以看到VideoTag中开始处增加了一段SEI数据,并且可以看到部分字段,gameid.time. ...
- Python 潮流周刊#53:我辈楷模,一个约见诺奖得主,一个成为核心开发者
本周刊由 Python猫 出品,精心筛选国内外的 250+ 信息源,为你挑选最值得分享的文章.教程.开源项目.软件工具.播客和视频.热门话题等内容.愿景:帮助所有读者精进 Python 技术,并增长职 ...
- 规则引擎easyRules中组合规则的使用
这两天想要做支付路由,要根据支付信息将支付请求转发到不同的支付渠道,可能要用到规则引擎,于是研究了一下开源的规则引擎产品.规则引擎核心知识与开源产品对比选型 ,这篇文章对规格引擎和开源产品有详细的介绍 ...
- IMX6ULL基本环境搭建
基本环境搭建 1 交叉编译工具 在虚拟机中安装交叉编译工具,为后续开发做准备. 1.1 工具版本 工具版本:Linaro Releases 当前虚拟机为64位系统,因此下载64位系统的工具: $ un ...
- undefined和null js数据类型转换自动转换布尔类型
基本数据类型之undefined和null undefined是表示未找到,是变量没有正确赋值数据时,生成的数据类型 var int : console.log(int)//undefined nul ...
- 剑指Offer-59.按之字形顺序打印二叉树(C++/Java)
题目: 请实现一个函数按照之字形打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,其他行以此类推. 分析: 实际上是二叉树的层次遍历,只不过每一行 ...
- RestApi请求地址支持多路径访问
RestApi请求地址支持多路径访问 @RestController@RequestMapping("/test") //单路径@RequestMapping(path = {&q ...
- Merry Christmas 礼物
Tips:当你看到这个提示的时候,说明当前的文章是由原emlog博客系统搬迁至此的,文章发布时间已过于久远,编排和内容不一定完整,还请谅解` Merry Christmas 礼物 日期:2020-12 ...