题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1002

打表找规律,似乎是这样:https://blog.csdn.net/fzhvampire/article/details/46389897

代码如下:

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int n;
struct N{
int a[];
N(){memset(a,,sizeof a);}
}f[],ans;
N add(N x,N y)
{
N ret;
ret.a[]=max(x.a[],y.a[]);
for(int i=;i<=ret.a[];i++)
ret.a[i]=x.a[i]+y.a[i];
for(int i=;i<=ret.a[];i++)
{
int t=ret.a[i]/; ret.a[i]%=;
ret.a[i+]+=t;
}
if(ret.a[ret.a[]+])ret.a[]++;
return ret;
}
N pw(N x)
{
N ret;
ret.a[]=*x.a[];
for(int i=;i<=x.a[];i++)
for(int j=;j<=x.a[];j++)
ret.a[i+j-]+=x.a[i]*x.a[j];
for(int i=;i<=ret.a[];i++)
{
int t=ret.a[i]/; ret.a[i]%=;
ret.a[i+]+=t;
}
if(ret.a[ret.a[]+])ret.a[]++;
while(ret.a[ret.a[]]==&&ret.a[])ret.a[]--;
return ret;
}
void sub(int k)
{
ans.a[]-=k; int i=;
while(ans.a[i]<)ans.a[i]+=,ans.a[++i]--;
while(ans.a[ans.a[]]==&&ans.a[])ans.a[]--;
}
void print()
{
for(int i=ans.a[];i;i--)printf("%d",ans.a[i]);
}
int main()
{
scanf("%d",&n);
f[].a[]=; f[].a[]=;
f[].a[]=; f[].a[]=;
for(int i=;i<=n;i++)
f[i]=add(f[i-],f[i-]);
ans=pw(f[n]);
if(n%==)sub();
print();
return ;
}

还有大家都在说的结论:http://vfleaking.blog.163.com/blog/static/17480763420119685112649/

也就是:f[i] = ( f[i-1]*3 - f[i-2] + 2 )

代码如下:

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int n;
struct N{
int a[];
// N(){memset(a,0,sizeof a);}
}f[],ans;
N sub(N x,N y)
{
x.a[]+=;
int j=;
while(x.a[j]>=){x.a[j]%=;x.a[j+]++;j++;}
for(int i=;i<=x.a[];i++)
{
x.a[i]-=y.a[i];
if(x.a[i]<)x.a[i]+=,x.a[i+]--;
}
// for(int i=1;i<=x.a[0];i++)
// if(x.a[i]<0)x.a[i]+=10,x.a[i+1]--;
while(x.a[x.a[]]==&&x.a[])x.a[]--;
return x;
}
//N add(N x,int k)
//{
// x.a[1]+=k; int i=1;
// while(x.a[i]>=10)x.a[i+1]+=x.a[i]/10,x.a[i]%=10,i++;
// if(x.a[x.a[0]+1])x.a[0]++;
// return x;
//}
N mul(N x,int k)
{
for(int i=;i<=x.a[];i++)x.a[i]*=k;
for(int i=;i<=x.a[];i++)
{
x.a[i+]+=x.a[i]/; x.a[i]%=;
}
if(x.a[x.a[]+])x.a[]++;
return x;
}
void print()
{
for(int i=f[n].a[];i;i--)printf("%d",f[n].a[i]);
}
int main()
{
scanf("%d",&n);
f[].a[]=; f[].a[]=;
f[].a[]=; f[].a[]=;
for(int i=;i<=n;i++)
{
// f[i]=mul(f[i-1],3);
// f[i]=sub(f[i],f[i-2]);
// f[i]=add(f[i],2);
f[i]=sub(mul(f[i-],),f[i-]);
}
print();
return ;
}

果然考场上还是打表找规律比较靠谱...

然而为什么,我的代码跑得好慢...

bzoj1002 [FJOI2007]轮状病毒——找规律+高精度的更多相关文章

  1. BZOJ1002:[FJOI2007]轮状病毒(找规律,递推)

    Description 轮状病毒有很多变种,所有轮状病毒的变种都是从一个轮状基产生的.一个N轮状基由圆环上N个不同的基原子 和圆心处一个核原子构成的,2个原子之间的边表示这2个原子之间的信息通道.如下 ...

  2. BZOJ [FJOI2007]轮状病毒 (找规律)

    1002: [FJOI2007]轮状病毒 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 6009  Solved: 3282[Submit][Statu ...

  3. [FJOI2007]轮状病毒 题解(dp(找规律)+高精度)

    [FJOI2007]轮状病毒 题解(dp(找规律)+高精度) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1335733 没什么好说的,直接把规律找出来,有 ...

  4. BZOJ1002 FJOI2007 轮状病毒 【基尔霍夫矩阵+高精度】

    BZOJ1002 FJOI2007 轮状病毒 Description 轮状病毒有很多变种,所有轮状病毒的变种都是从一个轮状基产生的.一个N轮状基由圆环上N个不同的基原子和圆心处一个核原子构成的,2个原 ...

  5. [bzoj1002][FJOI2007]轮状病毒_递推_高精度

    轮状病毒 bzoj-1002 FJOI-2007 Description 轮状病毒有很多变种,所有轮状病毒的变种都是从一个轮状基产生的.一个N轮状基由圆环上N个不同的基原子和圆心处一个核原子构成的,2 ...

  6. 【BZOJ1002】[FJOI2007]轮状病毒 递推+高精度

    Description 给定n(N<=100),编程计算有多少个不同的n轮状病毒. Input 第一行有1个正整数n. Output 将编程计算出的不同的n轮状病毒数输出 Sample Inpu ...

  7. 【BZOJ】1002: [FJOI2007]轮状病毒 递推+高精度

    1002: [FJOI2007]轮状病毒 Description 给定n(N<=100),编程计算有多少个不同的n轮状病毒. Input 第一行有1个正整数n. Output 将编程计算出的不同 ...

  8. BZOJ 1002 FJOI2007 轮状病毒 递推+高精度

    题目大意:轮状病毒基定义如图.求有多少n轮状病毒 这个递推实在是不会--所以我选择了打表找规律 首先执行下面程序 #include<cstdio> #include<cstring& ...

  9. bzoj1002: [FJOI2007]轮状病毒(基尔霍夫矩阵)

    1002: [FJOI2007]轮状病毒 题目:传送门 题解: 决定开始板刷的第一题... 看到这题的时候想:这不就是求有多少种最小生成树的方式吗? 不会啊!!!%题解... 什么鬼?基尔霍夫矩阵?? ...

随机推荐

  1. 《深入理解mybatis原理7》 MyBatis的二级缓存的设计原理

    <深入理解mybatis原理> MyBatis的二级缓存的设计原理 MyBatis的二级缓存是Application级别的缓存,它可以提高对数据库查询的效率,以提高应用的性能.本文将全面分 ...

  2. IOS-CALayer(图层)

    BWLayer.m // // BWLayer.m // IOS_0222_CALayer // // Created by ma c on 16/2/23. // Copyright © 2016年 ...

  3. ansible入门五

    一.Ansible条件测试 在ansible中还可以进行条件测试.如果需要根据变量.facts或此前任务的执行结果来做为某task执行与否的前提时要用到条件测试. 1. when语句 在task后添加 ...

  4. Yii ExtendedActiveRecord 增强版 ActiveRecord 增加多数据库连接绑定功能

    ExtendedActiveRecord 继承自 CActiveRecord,因此基础功能与 CActiveRecord 无异 为添加对多数据库连接的支持,增加了对 connectionName() ...

  5. DB2导入导出数据

    1.导出表数据到txt文件: export to /brcb_edp/data_public_edp/file/CCDM/file/FILE_CCDM_DR_CARD_CUST_DET.txt of ...

  6. C与C++基础知识补遗

    本随笔用来记载项目开发中遇到的以前没掌握的C/C++基础知识 void * buffer; 无类型指针,可以指向任何类型数据.ANSI标准规定无类型指针不能进行算法,而GNU规定无类型指针算法操作与c ...

  7. mac下解决mysql乱码问题

    问题描述:在window平台下面数据库插入.已经查找都是很正常的,但是到mac下面查找.插入就不正常了,之后感觉是mysql的问题然后网上搜索学习了下,果然是mysql的问题.解决方案:首先你要先去看 ...

  8. recovery.conf文件详解

    在恢复过程中,用户可以通过使用recovery.conf文件来指定恢复的各个参数,如下: 归档恢复设置 restore_command:用于获取一个已归档段的XLOG日志文件的命令 archive_c ...

  9. 特征金字塔网络 FPN

    一. 提出背景 论文:Feature Pyramid Networks for Object Detection  [点击下载] 在传统的图像处理方法中,金字塔是比较常用的一种手段,像 SIFT 基于 ...

  10. printf格式输出数字,位数不够前面补0,适用与输出编号

    printf格式输出数字,位数不够前面补0,适用与输出编号 printf格式输出:%[flags][width][.perc][F|N|h|l]type 用到了flags中的 0 (注意是零不是欧) ...