BZOJ 1002 FJOI 2007 轮状病毒 暴力+找规律+高精度
题目大意:
思路:基尔霍夫矩阵求生成树个数,不会。
可是能够暴力打表。(我才不会说我调试force调试了20分钟。。。
CODE(force.cc):
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#define MAX 1000
using namespace std; struct Edge{
int x,y; Edge(int _,int __):x(_),y(__) {}
Edge() {}
}edge[MAX]; int edges;
int status; int father[MAX]; int Find(int x)
{
if(father[x] == x) return x;
return father[x] = Find(father[x]);
} inline bool Unite(int x,int y)
{
int fx = Find(x);
int fy = Find(y);
if(fx != fy) {
father[fx] = fy;
return true;
}
return false;
} int main()
{
for(int i = 1; i <= 20; ++i) {
edges = 0;
for(int j = 1; j <= i; ++j)
edge[++edges] = Edge(0,j);
for(int j = 1; j < i; ++j)
edge[++edges] = Edge(j,j + 1);
edge[++edges] = Edge(i,1);
int ans = 0;
for(int j = 1; j <= (1 << edges); ++j) {
int added = 0;
for(int k = 0; k <= i; ++k)
father[k] = k;
for(int k = 0; k < edges; ++k)
added += (j >> k)&1;
if(added != i) continue;
added = 0;
for(int k = 0; k < edges; ++k)
if((j >> k)&1)
added += Unite(edge[k + 1].x,edge[k + 1].y);
ans += (added == i);
}
cout << i << ':' << ans << endl;
}
return 0;
}
打出的表是这种。。
后面的数太大了爆了。
。
非常明显能够看出奇数的数都是全然平方数。
把它们开跟,然后经过艰苦卓绝的分析之后,得到了一个递推式:
f[i] = f[i - 1] + Σf[j] + 2 (j∈[1,i - 1]),答案是f[n] ^ 2
有了这个结论,偶数的就好办了。能够看到,偶数的除以5之后也是全然平方数,和上面非常像,它的递推式是:
f[i] = f[i - 1] + Σf[j] + 1 (j∈[i,i - 1]),答案是f[n] ^ 2 * 5
至于为什么递推式长这样,谜。
CODE:
#include <cstdio>
#include <iomanip>
#include <cstring>
#include <iostream>
#include <algorithm>
#define BASE 10000
#define MAX 1010
using namespace std; struct BigInt{
int num[MAX],len; BigInt(int _ = 0) {
memset(num,0,sizeof(num));
len = _ ? 1:0;
num[1] = _;
}
BigInt operator +(const BigInt &a)const {
BigInt re;
re.len = max(len,a.len);
int temp = 0;
for(int i = 1; i <= re.len; ++i) {
re.num[i] = num[i] + a.num[i] + temp;
temp = re.num[i] / BASE;
re.num[i] %= BASE;
}
if(temp) re.num[++re.len] = temp;
return re;
}
BigInt operator *(const BigInt &a)const {
BigInt re;
for(int i = 1; i <= len; ++i)
for(int j = 1; j <= a.len; ++j) {
re.num[i + j - 1] += num[i] * a.num[j];
re.num[i + j] += re.num[i + j - 1] / BASE;
re.num[i + j - 1] %= BASE;
}
re.len = len + a.len;
if(!re.num[re.len]) --re.len;
return re;
}
}; ostream &operator <<(ostream &os,const BigInt &a)
{
os << a.num[a.len];
for(int i = a.len - 1; i; --i)
os << fixed << setw(4) << setfill('0') << a.num[i];
return os;
} int k;
BigInt f[110],g[110]; int main()
{
cin >> k;
if(k&1) {
k = (k + 1) >> 1;
f[1] = BigInt(1),f[2] = BigInt(4);
g[1] = BigInt(1),g[2] = BigInt(5);
for(int i = 3; i <= k; ++i) {
f[i] = f[i - 1] + g[i - 1] + BigInt(2);
g[i] = g[i - 1] + f[i];
}
cout << f[k] * f[k] << endl;
}
else {
k >>= 1;
f[1] = BigInt(1),f[2] = BigInt(3);
g[1] = BigInt(1),g[2] = BigInt(4);
for(int i = 3; i <= k; ++i) {
f[i] = f[i - 1] + g[i - 1] + BigInt(1);
g[i] = g[i - 1] + f[i];
}
cout << f[k] * f[k] * BigInt(5) << endl;
}
return 0;
}
BZOJ 1002 FJOI 2007 轮状病毒 暴力+找规律+高精度的更多相关文章
- BZOJ 1002 [ FJOI 2007 ]
-------------------------萌萌哒分割线------------------------- 题目很容易看懂,数据范围也不大.当然可以卡过暴力的人了. 在n=1时很明显是一种,如下 ...
- [FJOI2007]轮状病毒 题解(dp(找规律)+高精度)
[FJOI2007]轮状病毒 题解(dp(找规律)+高精度) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1335733 没什么好说的,直接把规律找出来,有 ...
- bzoj1002 [FJOI2007]轮状病毒——找规律+高精度
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1002 打表找规律,似乎是这样:https://blog.csdn.net/fzhvampir ...
- ACM_同余+暴力找规律
小光的忧伤 Time Limit: 2000/1000ms (Java/Others) Problem Description: 锴神:我尊重作者原意,你们出什么我就加什么.于是小光打了道水题(也就是 ...
- BZOJ 4706: B君的多边形 找规律
4706: B君的多边形 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=4706 Description 有一个正n多边形,我们要连接一些 ...
- BZOJ 1228 E&G(sg函数+找规律)
把一对石子堆看出一个子游戏.打出子游戏的sg表找规律.. 这个规律我是一定找不出来的... 对于i,j,如果 (i-1)%pow(2,k+1) < pow(2,k) (j-1)%pow(2,k+ ...
- 【BZOJ】1002: [FJOI2007]轮状病毒(DP+规律+高精度)
http://www.lydsy.com/JudgeOnline/problem.php?id=1002 其实我还是看题解的,而且看了题解也没明白那公式怎么来的T_T,先水过了先把....以后研究一下 ...
- [BZOJ1002](FJOI 2007) 轮状病毒
[题目描述] 给定n(N<=100),编程计算有多少个不同的n轮状病毒. [输入格式] 第一行有1个正整数n. [输出格式] 将编程计算出的不同的n轮状病毒数输出 [样例输入] 3 [样例输出] ...
- ZOJ 3939 The Lucky Week (暴力找规律)
题意:给定一个幸运日,求第 k 个幸运日是多少. 析:由于闰年,每400肯定会循环一次,所以我们就可以先找出每400年会有多少幸运日,是2058个,然后再暴力. 代码如下: #pragma comme ...
随机推荐
- vue项目input的placeholder根据用户的选择改变
html部分 <el-input :placeholder="holder" v-model="searchKey"> <el-select ...
- 服务器搭建域控与SQL Server的AlwaysOn环境过程(二) 搭建客户端节点 服务器
1. 修改客户端服务器的计算机名,重启后,如果服务器属于克隆服务器,需要修改服务器SID,如果没有则调过这一步. 命令行方式:启动Windows2008进入系统后,打开“CMD窗口”并进入到" ...
- 一个渣渣python脚本,用wol控制开机
#!/usr/bin/env python #coding:utf8 import os,time d={} '''f = open('E:\info.txt','r') for ipmac in f ...
- vmware vsphere出现“需要整合虚拟机磁盘”的告警处理方法(完整版)
vmware vsphere出现“需要整合虚拟机磁盘”的告警 处理步骤: 1.选择对应虚机,快照——整合 (不行看下一条) 通常情况执行完第一步就好了 2.如果整合报错,提示文件锁定 2.1 新建快照 ...
- mycat详细
MyCAT的优势基于阿里开源的Cobar产品而研发,Cobar的稳定性.可靠性.优秀的架构和性能以及众多成熟的使用案例使得MYCAT一开始就拥有一个很好的起点,站在巨人的肩膀上,我们能看到更远.业界优 ...
- enterprise architect (EA) 源码生成UML类图,帮助理解项目工程
用VS看大型工程代码,尤其是很多层类的,很容易头晕,即便是装了visual assist 插件.用VS生成类图吧,只能生成一堆框,只有一些小的类关系有箭头表示.远远不能满足要求.下面介绍建模工具EA来 ...
- javascript位操作符右移>>>的妙用
var len=arr.length>>>0; 在arr.length为null或undefined的时间,强制转换为0;
- 洛谷 P1033 自由落体
P1033 自由落体 题目描述 在高为 H 的天花板上有 n 个小球,体积不计,位置分别为 0,1,2,….n-1.在地面上有一个小车(长为 L,高为 K,距原点距离为 S1).已知小球下落距离计算公 ...
- 不安装Oracle客户端,用plsql连接远程Oracle数据库(绝对解决你的问题)
1,首先准备下载两个软件,一个是instantclient.zip,另一个是plsql安装包.但是得确定您的电脑是32位还是64位,我这边提供了32位和64位的供您下载: 百度网盘:https://p ...
- 查看spark是否有僵尸进程,有的话,先杀掉。可以使用下面命令
查看spark是否有僵尸进程,有的话,先杀掉.可以使用下面命令yarn application -listyarn application -kill <jobid>