1. 高精度
这题略水,字符串可过,还不加压位等,操作只有BitShift和add/sub,不过编程复杂度有些高.(输出都是二进制我能说些什么...)
2. N皇后问题 (警告! 不是平时你见到的N皇后问题...是一道Hash的模拟题,N皇后的位置都给你了,就是统计)
二级标题很详细了,搜索那些解N皇后问题的千万莫戳进来.
3. Sam数
一道比较有意思的题.
题意是,给定一个k,求所有k位数中所有相邻两位数差都小于等于2的数.输出$\mod{10^9+7}$
说的不够明白.来个例子:
$2134678$ 这是一个符合要求的7阶Sam数.
$6987688$ 这个不符合,$\left| 9-6\right|=3>2$
很明显,当$k=1$时输出$10$.
当$k=2$时,很明显最高位不可为0.
于是第一位只能为$1~9$.
第二位呢?显然不可能是$0~10$.限制条件摆那儿呢!
于是想到,第二位是$0$的时候有两种可能,即$10$和$20$.这是从第一位是$0,1,2$的地方推导来的.
于是递推式很明显,$F[i,j]=\sum_{n=j-2}^{j+2}F[i-1,n]\text{While n}\in\text{0~9}$
可是数据范围:
$30\% k\le 10^6,60\% k\le 10^{12},100\% 10^{18}$
吓,$10^6 \cdot 10$都基本爆空间好么? 逗我呢?
注意到每次递推只需用到前一次的结果,用滚动数组即可. 30分到手.
但是,十的十八次位数这是要闹那样!!!
车到山前必有路(话说我当时还没想到).
注意这是线性递推.每次递推后的$F[i]$都是前一次值的线性组合($\text{linear combination}$),而这事可以用矩阵乘法解决.矩阵乘法遵守结合率,可以使用二分快速幂在$O(\log{n})$时间内求出.至于矩阵乘法的复杂度...他不会随着输入数据的上升而上升,$O(n^3)$中n恒等于10,即是常数时间,只是常数比较大.
时间复杂度是$O(1000 \cdot \log(n))=O(\log{n})$.
矩阵方法详细参数:
变换矩阵:
$tr=\left[ \begin{array} {lcr}
1 & 1 & 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
1 & 1 & 1 & 1 & 0 & 0 & 0 & 0 & 0 & 0 \\
1 & 1 & 1 & 1 & 1 & 0 & 0 & 0 & 0 & 0 \\
0 & 1 & 1 & 1 & 1 & 1 & 0 & 0 & 0 & 0 \\
0 & 0 & 1 & 1 & 1 & 1 & 1 & 0 & 0 & 0 \\
0 & 0 & 0 & 1 & 1 & 1 & 1 & 1 & 0 & 0 \\
0 & 0 & 0 & 0 & 1 & 1 & 1 & 1 & 1 & 0 \\
0 & 0 & 0 & 0 & 0 & 1 & 1 & 1 & 1 & 1 \\
0 & 0 & 0 & 0 & 0 & 0 & 1 & 1 & 1 & 1 \\
0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 & 1 & 1
\end{array} \right]$
初始向量:
$i=\left[ \begin{array} {lcr}
0 \\
1 \\
1 \\
1 \\
1 \\
1 \\
1 \\
1 \\
1 \\
1
\end{array} \right]$
递推结果为$c = tr^k \cdot i$
结果
$$sum=\sum_{i \in c}c[i]$$
注意随时求余.特判k=1.
最后一题代码(前两题还要?自己写去..)
#include "cstdio"
#define modulo 1000000007
#include "cstring"
struct mat{
long long m[10][10],i,j,k,t;
void cpy(mat b){
for(i=0;i<10;++i)
for(j=0;j<10;++j)
m[i][j]=b.m[i][j];
}
void mul(mat a){
mat tempa;
for(i=0;i<10;++i){
for(j=0;j<10;++j){
t=0;
for(k=0;k<10;++k){
t+=m[k][i]*a.m[j][k];
}
tempa.m[i][j]=t % modulo;
}
}
cpy(tempa);
}
void toUnit(){
memset(m,0,sizeof(m));
for(i=0;i<10;++i){
m[i][i]=1;//unit in matrix computation,oops...
}
}
} matt,tt;
struct vect{
long long m[10],tm;
int i,j;
void mul(mat a){
for(i=0;i<10;++i){
tm=0;
for(j=0;j<10;++j){
tm+=m[i]*a.m[i][j];
}
m[i]=tm % modulo;
}
}
} vec;
long long n,ac;
void fastPow(long long n){
if(n&1){
tt.cpy(matt);
}else{
tt.toUnit();
}
while(n>>=1){
matt.mul(matt);
if(n&1){
tt.mul(matt);
}
}
}
const long long pa[10]={0,1,1,1,1,1,1,1,1,1};
const long long pb[10][10]={
{1,1,1,0,0,0,0,0,0,0},
{1,1,1,1,0,0,0,0,0,0},
{1,1,1,1,1,0,0,0,0,0},
{0,1,1,1,1,1,0,0,0,0},
{0,0,1,1,1,1,1,0,0,0},
{0,0,0,1,1,1,1,1,0,0},
{0,0,0,0,1,1,1,1,1,0},
{0,0,0,0,0,1,1,1,1,1},
{0,0,0,0,0,0,1,1,1,1},
{0,0,0,0,0,0,0,1,1,1}
};
int main(){
scanf("%lld",&n);
if(n==1){
printf("10\n");
return 0;
}
memcpy(vec.m,pa,sizeof(pa));
memcpy(matt.m,pb,sizeof(pb)); fastPow(n-1);//幂次修正
vec.mul(tt);
ac=0;
for(int i=0;i<10;++i){
ac+=vec.m[i];
}
printf("%lld\n",ac % modulo);
return 0;
}
常州Day4题解的更多相关文章
-
【2018.8.10】四连测day4 题解
T1:给出一棵 $n$ 个节点的无根树,其中 $m$ 个节点是特殊节点,求对于任意 $i ∈ [0, m]$,包含 $i$ 个特殊节点的联通块个数$\mod 998244353$. $1<=n, ...
-
【2016常州一中夏令营Day4】
小 W 走迷宫[问题描述]小 W 被小 M 困在了一个方格矩阵迷宫里,矩阵边界在无穷远处,我们做出如下的假设:a. 每走一步时,只能从当前方格移动一格,走到某个相邻的方格上:b. 走过的格子立即塌陷无 ...
-
常州培训 day4 解题报告
第一题:(简单的模拟题) 给出一个N位二进制数,有‘+’, ‘-’, ‘*’, ‘/’ 操作,分别表示加1,减1,乘2,除以2,给出M个操作,求出M个操作后的二进制数.N,M<=5000000; ...
-
2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
-
noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
-
BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
-
Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
-
哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
-
2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
随机推荐
-
js 表单操作
order.aspx 订单页- order-detail.aspx订单确认页- 操作:order.aspx提交订单@1,跳转到order-detail.aspx页面,确认页面操作:返回上一步@2- ...
-
WinForm实现简单的拖拽功能(C#)(2)
首先创建一个winform应用程序,添加listbox1与listbox2,拖拽listbox1的项到listbox2上去. 具体代码如下 namespace OLE拖拽{ public partia ...
-
CS0016: 未能写入输出文件*****目录名称无效
一大早,杀毒软件弹出删除隐私记录.清理空间一堆堆的提醒,一般我都是无视它,今天顺便点了下清理,然后出问题. 昨晚下班提交的代码,程序运行好好地,今早清理完系统,竟然就出问题了, 具体如下 CS0016 ...
-
NginX issues HTTP 499 error after 60 seconds despite config. (PHP and AWS)
FROM: http://*.com/questions/15613452/nginx-issues-http-499-error-after-60-seconds-despi ...
-
HTML5行业现状与未来 - 2016年终大盘点
* { margin: 0; padding: 0 } .con { width: 802px; margin: 0 auto; text-align: center; position: inher ...
-
Python-1 试玩OpenCV
昨天同事说微信更新有跳一跳小游戏,便更新了玩一玩.至于抄袭不抄袭我不讨论,看玩法和色彩都很简洁.想用Python试试摄像头捕捉图像,然后分析距离每次都能跳到中心,有生物机械手指之类的再弄到树莓派上岂不 ...
-
CCNA学习与实验指南——第3章 以太网
以太网就是局域网,IEEE制定了802.2和802.3两种标准.802.2规定了OSI模型的数据链路层的上半部分(LLC子层),802.3规定了OSI模型的数据链路层的下半部分和物理层(MAC子层). ...
-
Windows系统之hosts文件
对于Hosts文件相信很多Win7的系统用户会比较陌生,其实Hosts是一个没有扩展名的系统文件,可以用记事本等工具打开,其作用就是将一些常用的网址域名与其对应的IP地址建立一个关联“数据库”,所以功 ...
-
spring boot 学习入门篇【spring boot项目的搭建以及如何加载jsp界面】
[ 前言] Spring Boot 简介:Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置, ...
-
PHP获取数组中奇偶数
获取PHP数组中的奇偶数,可通过数组过滤函数array_filter(),看定义:该函数把输入数组中的每个键值传给回调函数.如果回调函数返回 true,则把输入数组中的当前键值返回结果数组中.数组键名 ...