题目大意:轮状病毒基定义如图。求有多少n轮状病毒

这个递推实在是不会……所以我选择了打表找规律

首先执行下面程序

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define M 110
using namespace std;
struct abcd{
int to,next;
bool ban;
}table[M<<2];
int head[M],tot=1;
int n,ans;
void Add(int x,int y)
{
table[++tot].to=y;
table[tot].next=head[x];
head[x]=tot;
}
int fa[M],v[M],q[M],r,h;
bool BFS()
{
int i;
r=h=0;
memset(v,0,sizeof v);
memset(fa,-1,sizeof fa);
q[++r]=0;
while(r!=h)
{
int x=q[++h];
for(i=head[x];i;i=table[i].next)
if(!table[i].ban)
{
if(table[i].to==fa[x])
continue;
if(v[table[i].to])
return 0;
fa[table[i].to]=x;
v[table[i].to]=1;
q[++r]=table[i].to;
}
}
if(r<=n)
return 0;
return 1;
}
void DFS(int x)
{
if(x+x>tot)
{
if( BFS() )
++ans;
return ;
}
table[x<<1].ban=table[x<<1|1].ban=0;
DFS(x+1);
table[x<<1].ban=table[x<<1|1].ban=1;
DFS(x+1);
}
int main()
{
int i;
while(1)
{
memset(head,0,sizeof head);
tot=1;ans=0;
cin>>n;
for(i=1;i<=n;i++)
Add(0,i),Add(i,0),Add(i,i%n+1),Add(i%n+1,i);
DFS(1);
cout<<ans<<endl;
}
}

够简单。够暴力吧

然后打表。1~14的答案例如以下

1 5 16 45 121 320 841 2205 5776 15125 39601 103680 271441 710645

奇数项

1 16 121 841 5776 39601 271441

开根号得

1 4 11 29 76 199 521

a[i]=a[i-1]*3-a[i-2]

偶数项

5 45 320 2205 15125 103680 710645

除以5得

1 9 64 441 3025 20736 142129

开根号得

1 3 8 21 55 144 377

a[i]=a[i-1]*3-a[i-2]

然后高精度递推即可了

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
struct abcd{
int x[100],cnt;
int& operator [] (int y)
{
return x[y];
}
void operator = (int y)
{
x[1]=y;
cnt=1;
}
}f[100];
abcd operator - (abcd x,abcd &y)
{
int i;
abcd z=f[0];
z.cnt=max(x.cnt,y.cnt);
for(i=1;i<=z.cnt;i++)
{
z[i]+=x[i]-y[i];
if(z[i]<0)
z[i+1]--,z[i]+=10;
}
while(z.cnt&&!z[z.cnt])
z.cnt--;
return z;
}
abcd operator * (abcd &x,abcd &y)
{
int i,j;
abcd z=f[0];
for(i=1;i<=x.cnt;i++)
for(j=1;j<=y.cnt;j++)
z[i+j-1]+=x[i]*y[j],z[i+j]+=z[i+j-1]/10,z[i+j-1]%=10;
z.cnt=x.cnt+y.cnt;
if(!z[z.cnt])
--z.cnt;
return z;
}
abcd operator * (abcd x,int y)
{
int i;
abcd z=f[0];
for(i=1;i<=x.cnt;i++)
z[i]+=x[i]*y,z[i+1]+=z[i]/10,z[i]%=10;
z.cnt=x.cnt;
if(z[z.cnt+1])
++z.cnt;
return z;
}
ostream& operator << (ostream &os,abcd x)
{
int i;
for(i=x.cnt;i;i--)
os<<x[i];
return os;
}
int n;
int main()
{
int i;
cin>>n;
f[1]=1;
f[2]=n&1?4:3;
for(i=3;i+i<=n+1;i++)
f[i]=f[i-1]*3-f[i-2];
cout<<f[n+1>>1]*f[n+1>>1]*(n&1?1:5)<<endl;
}

BZOJ 1002 FJOI2007 轮状病毒 递推+高精度的更多相关文章

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

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

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

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

  3. bzoj 1002 [FJOI2007]轮状病毒 高精度&&找规律&&基尔霍夫矩阵

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

  4. BZOJ 1002: [FJOI2007]轮状病毒【生成树的计数与基尔霍夫矩阵简单讲解+高精度】

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

  5. BZOJ 1002 [FJOI2007]轮状病毒

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

  6. 生成树的计数(基尔霍夫矩阵):BZOJ 1002 [FJOI2007]轮状病毒

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

  7. 【刷题】BZOJ 1002 [FJOI2007]轮状病毒

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

  8. bzoj 1002 [FJOI2007]轮状病毒——打表找规律

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1002 看 Zinn 的博客:https://www.cnblogs.com/Zinn/p/9 ...

  9. 1002: [FJOI2007]轮状病毒

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

随机推荐

  1. Shell中的单引号(‘)双引号(”)和反引号(·)

    在bash中,$.*.?.[.].’.”.`.\.有特殊的含义.类似于编译器的预编译过程,bash在扫描命令行的过程中,会在文本层次上,优先解释所有的特殊字符,之后对转换完成的新命令行,进行内核的系统 ...

  2. dhlin-vim-wiki

    记录vim中常用的几个操作 入门指南 $ vimtutor vim中是区分大小写 vim中移动光标 h 向左移动 j 向下移动 k 向上移动 l 向右移动 其实使用方向键也是能移动的,但是熟悉后再一些 ...

  3. poj 3140 Contestants Division [DFS]

    题意:一棵树每个结点上都有值,现删掉一条边,使得到的两棵树上的数值和差值最小. 思路:这个题我直接dfs做的,不知道树状dp是什么思路..一开始看到数据规模有些后怕,后来想到long long 可以达 ...

  4. SpringMVC_01:创建运行环境(Maven)

    Maven 环境下配置: 1.新建MavenProject,打包选线根据情况选择jar war和pom jar:打包为jar包,主要用于被其他项目引用 war:打包为war包,可直接运行于服务器 po ...

  5. 记录一次(xheditor-1.1.6-zh-cn.min.js)的错误:Cannot read property 'match' of undefined的问题解决

    由于使用了xheditor富文本框,且这个版本是2011年开发的系统,当时只有IE8,所以一切正常. 但是问题来了,今天使用IE11测试和谷歌浏览器测试,发现一直报这个错误: 且google了一下,没 ...

  6. uiaotumator ui測试 高速调试

    1. uiaotumator ui測试 Demo.java package uiautomatorDemo1; import java.io.File; import android.graphics ...

  7. Windows网络编程 2 【转】

    Windows网络编程使用winsock.Winsock是一个基于Socket模型的API,在Windows系统中广泛使用.使用Winsock进行网络编程需要包含头文件Winsock2.h,需要使用库 ...

  8. docker入门小结(二)

    11,网络使用 sudo docker run -d -P training/webapp python app.py sudo docker ps -l 这样将主机一个端口映射到容器中,由于app. ...

  9. UE把环境变量Path改了

    为了比较个文件,装了UE. 文件比较完了,环境变量也被改了. 改还不是写添加式的改,是写覆盖式的改. 搞得ant都起不动了,一看Path被改的那样(C:\hy\soft\ultraedit\Ultra ...

  10. $ is not defined

    $ is not defined 引入Jquery的顺序不正确,要把它放在第一个引入