脑子一热报了CCF的软测。。但是又觉得好像并没有什么卵用,就当为蓝桥杯预热然后顺便去软件学院玩一玩吧,遇到一个有意思的题:

time limits : 1s

问题描述
  我们把一个数称为有趣的,当且仅当:
  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
数位统计问题。。臣妾真的做不到啊。。把网上的两种方法在这里总结一下下。
方法一:数位DP
容易得到(我他妈怎么没想到),每一个n位有趣的数,都是从n-1位的某个数转移过来的(n-1位可能不是有趣的数),那麽可以根据组成数字的元素,把数字分成这这么6种数字:
0:{2}---只含有2,很显然开头有趣的数的第一个数字肯定是2,类似2222;
1:{2,0}
2:{2,1}
3:{2,1,0}
4:{2,1,3}
5:全部4种数字
定义状态d【n】【6】;d【i】【j】表示i位数,状态为j的种类数;
转移很简单,d【i】【0】 = 1(只有2组成);
d【i】【1】 = (d[i-1][0] + d[i-1][1]*2)%mod;(可以在n-1位只含2的数后面加一位0,或在n-1位含有2,0的数后面加个0或2,以下都可以很轻松地推出,注意0在1前面,2在3前面)

d[i][2] = (d[i-1][0] + d[i-1][2])%mod;
d[i][3] = (d[i-1][1] + d[i-1][3]*2 )%mod;
d[i][4] = (d[i-1][2] + d[i-1][1] + d[i-1][4]*2)%mod;
d[i][5] = (d[i-1][3] + d[i-1][4] + d[i-1][5]*2)%mod;

另外注意会爆int

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn = + ;
const int mod = ;
int n;
ll d[maxn][];
int main()
{
for(int i = ; i <= ; ++i)
{
d[i][] = ;
d[i][] = (d[i-][] + d[i-][]*)%mod;
d[i][] = (d[i-][] + d[i-][])%mod;
d[i][] = (d[i-][] + d[i-][]* )%mod;
d[i][] = (d[i-][] + d[i-][] + d[i-][]*)%mod;
d[i][] = (d[i-][] + d[i-][] + d[i-][]*)%mod;
}
scanf("%d",&n);
printf("%lld\n",d[n][]);
}

方法二:推公式

能不能不递推,直接o(1)地算出答案呢?当然可以!

已知0,1,2,3都必须出现一次,那么我们可以枚举0,1出现的次数,或者说占用的位数;

0,1加在一起至少出现占2位,最多占n-2位,假设为i位,则首位为2,还剩n-1位,从n-1位里面挑i位分给0,1,有Cn-1,i种方案,然后0,1内部有i-1种排列方式,2,3内部有

n-i-1种反案,所以最后答案:

然而这种方法要o(n^2)利用杨辉三角预处理组合数,最后时间和第一种方法跑起来差不多。

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn = + ;
const int mod = ;
int n;
ll c[maxn][maxn];
ll sum;
int main()
{
for(int i = ; i <= ; ++i)
{
c[i][] = ;
for(int j = ; j < i; ++j)
{
c[i][j] = (c[i-][j-] + c[i-][j])%mod;
}
c[i][i] = ;
}
scanf("%d",&n);
for(int i = ; i <= n-; ++i)
{
sum = (sum + c[n-][i]%mod*(i-)*(n-i-))%mod;
}
printf("%lld\n",sum);
}

方法三:矩阵,递推。。。待补充

CCF软考---《有趣的数》的更多相关文章

  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 201312-4 有趣的数 (数位DP, 状压DP, 组合数学+暴力枚举, 推公式, 矩阵快速幂)

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

  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. 软考类----编码、ASII码等

    淘米2014实习生笔试,今年是淘米第一年招暑期实习生,笔试好大部分考的是软考的题目啊啊啊啊(劳资后悔当年没考软考刷加权),其他是浅而泛的风格,C++,SQL语句,数据结构(哈夫曼树,二叉查找树,栈后缀 ...

  8. 软考计算机网络原理之IP计算问题汇总

    转自 http://www.cnblogs.com/jyh317/archive/2013/04/14/3018650.html 1.IP地址 分类: ①A类IP地址 ②B类IP地址 ③C类IP地址 ...

  9. 软考之PV操作(同步)

    这几天,陆续有那么三两个同学跟我讨论了一下关于软考上的PV操作的题,吾虽不才,但还是把同学们讲通了,在此,特分享一下自己的思路和想法,愿对大家有点帮助! 下面,我们就通过自己做过的试卷上两道题来分析: ...

随机推荐

  1. Java向上转型注意事项

    继承.接口:Java子类中如果含有父类中不包含的变量与方法,子类对象向上转型时就是丢失这些变量和方法. interface SuperClass{ int i = 2; void f() ; } cl ...

  2. 关于退运美国转基因玉米含有MRI 162转基因成分的质疑

    6月30日,新华社刊出文章"我国退运125.2万吨进口美国转基因玉米",读后有感. 文章说:国家质检总局办公厅副主任陆春明30日介绍,截至今年6月16日,全国出入境检验检疫机构共在 ...

  3. com.microsoft.sqlserver.jdbc.SQLServerException: 结果集没有当前行

    參考博客com.microsoft.sqlserver.jdbc.SQLServerException: 结果集没有当前行 java获取结果集,if(rs!=null).和while(rs.next( ...

  4. Python 正则表达试

    字符串是编程时涉及到的最多的一种数据结构,对字符串进行操作的需求几乎无处不在.比如判断一个字符串是否是合法的Email地址,虽然可以编程提取@前后的子串,再分别判断是否是单词和域名,但这样做不但麻烦, ...

  5. linux cat /proc/cpuinfo

    #cat /proc/cpuinfo processor : 0 #逻辑处理器的唯一标识符 vendor_id : AuthenticAMD #CPU厂商ID信息,如果处理器为英特尔处理器,则vend ...

  6. 【回顾整理】暴走的SQL语句练习!!!

    设计一个学生成绩数据库,该库包含学生,老师,课程和成绩等信息并完成后面的练习.学生:学号(SNO).姓名(SNAME).性别(SSEX).生日(SBIRTHDAY ).所属班级(SCLASS )课程: ...

  7. The type or namespace name 'Script' does not exist in the namespace 'System.Web' (are you missing an assembly reference?)

    应该说是 .net4 的bug,没有所谓的 System.Web.Extensions.dll 库文件,需要将项目的 Target Framework修改为 3.5版本,才能加载System.Web. ...

  8. hibernate 核心总结 (面试)

    1:1(类与类之间) husband----wife 外键关联: a)单向@OneToOne b)双向@OneToOne, mappedby="husband" --------- ...

  9. 使用DataSet数据集删除记录

    使用DataSet删除记录和使用DataSet更新记录非常的相似,DataSet删除记录的步骤如下所示. q  创建一个Connection对象. q  创建一个DataAdapter对象. q  初 ...

  10. HibernateTemplate常用方法总结

    HibernateTemplate常用方法 (本文章内容相当于转载自:http://www.tuicool.com/articles/fU7FV3,只是整理了一下内容结构和修改了部分内容,方便阅读) ...