洛谷 P2144 BZOJ 1003 [FJOI2007]轮状病毒
题目描述
轮状病毒有很多变种。许多轮状病毒都是由一个轮状基产生。一个n轮状基由圆环上n个不同的基原子和圆心的一个核原子构成。2个原子之间的边表示这2个原子之间的信息通道,如图1。
n轮状病毒的产生规律是在n轮状基中删除若干边,使各原子之间有唯一一条信息通道。例如,共有16个不同的3轮状病毒,入图2所示。
给定n(N<=100),编程计算有多少个不同的n轮状病毒。

输入输出格式
输入格式:
第一行有1个正整数n。
输出格式:
将编程计算出的不同的n轮状病毒数输出
输入输出样例
3
16
吐槽
今天(应该是昨天了)我的ubuntu感染wncry(想哭)2.0(惨痛经历),重装了快一整个前半夜的系统,我感到极端的不爽,于是想把这道WC2017时就想a掉但一直搁置的题切了,发泄心中的郁闷。
解题思路
%%%伏特跳蚤国王VFK大佬的博客http://vfleaking.blog.163.com/blog/static/17480763420119685112649/ //555……网易博客关了,看不了了
答案是求一个行列式的值,经过一大长串的公式推导化简(留坑),得到一个递推式——f[1]=1,f[2]=5,f[n+2]=f[n+1]*3-f[n]+2,n>=1(或者f[n]=f[n-1]*3-f[n-2]+2,n>=3),于是开始敲吧。
源代码
一开始我写了个__in128版本的
#include<bits/stdc++.h>
using namespace std;
int n;
__int128 a,b,c;
void print(__int128 x)
{
if (x==) return;
if (x) print(x/);
putchar(x%+'');
}
int main()
{
a=,b=;
cin>>n;
if(n==)
{
printf("1\n");
return ;
}
if(n==)
{
printf("5\n");
return ;
}
n-=;
while(n--)
{
c=b*-a+;
a=b;
b=c;
}
print(c);
printf("\n");
return ;
}
得了90分(评测记录)。第二个n=99的点wa了,n=99时__int128都爆了,但由于不想写高精,换成了unsigned __int128,照wa不误(评测记录)
而且BZOJ还不支持C++11,于是只得写高精了
#include<bits/stdc++.h>
using namespace std;
int n;
int a[],b[],c[];
void print(int * c)
{
int i=;
while(c[i]==) i--;
while(i>=) printf("%d",c[i--]);
}
int main()
{
a[]=,b[]=;
scanf("%d",&n);
if(n==)
{
printf("1\n");
return ;
}
if(n==)
{
printf("5\n");
return ;
}
for(int k=;k<=n;k++)
{
int len=;
while(b[len]==) len--;
for(int i=;i<=len;i++)
{
c[i]=b[i]*-a[i];
}
c[]+=;
for(int i=;i<;i++)
{
if(c[i]>)
{
c[i+]+=c[i]/;
c[i]%=;
}
if(c[i]<)
{
while(c[i]<)
c[i]+=,c[i+]--;
}
}
for(int i=;i<;i++)
{
a[i]=b[i],b[i]=c[i];
}
}
print(c);
printf("\n");
return ;
}
想想也有几个月没写过高精了,这么基础的姿势居然都忘的差不多了,我硬是调了快1个小时……在刷裸题学习新算法的时候还是不能忘记基础啊,还要多做点综合性的题目才行啊!
洛谷 P2144 BZOJ 1003 [FJOI2007]轮状病毒的更多相关文章
- 【洛谷】2144:[FJOI2007]轮状病毒【高精度】【数学推导??(找规律)】
P2144 [FJOI2007]轮状病毒 题目描述 轮状病毒有很多变种.许多轮状病毒都是由一个轮状基产生.一个n轮状基由圆环上n个不同的基原子和圆心的一个核原子构成.2个原子之间的边表示这2个原子之间 ...
- 洛谷 P2144 [FJOI2007]轮状病毒
P2144 [FJOI2007]轮状病毒 题目描述 轮状病毒有很多变种.许多轮状病毒都是由一个轮状基产生.一个\(n\)轮状基由圆环上\(n\)个不同的基原子和圆心的一个核原子构成.\(2\)个原子之 ...
- 洛谷 P3307: bzoj 3202: [SDOI2013] 项链
题目传送门:洛谷P3307.这题在bzoj上是权限题. 题意简述: 这题分为两个部分: ① 有一些珠子,每个珠子可以看成一个无序三元组.三元组要满足三个数都在$1$到$m$之间,并且三个数互质,两个珠 ...
- 洛谷 4106 / bzoj 3614 [HEOI2014]逻辑翻译——思路+类似FWT
题目:https://www.luogu.org/problemnew/show/P4106 https://www.lydsy.com/JudgeOnline/problem.php?id=3614 ...
- 洛谷 P3332 BZOJ 3110 [ZJOI2013]K大数查询
题目链接 洛谷 bzoj 题解 整体二分 Code #include<bits/stdc++.h> #define LL long long #define RG register usi ...
- 洛谷 P2486 BZOJ 2243 [SDOI2011]染色
题目描述 给定一棵有n个节点的无根树和m个操作,操作有2类: 1.将节点a到节点b路径上所有点都染成颜色c: 2.询问节点a到节点b路径上的颜色段数量(连续相同颜色被认为是同一段),如“112221” ...
- 洛谷 P2827 BZOJ 4721 UOJ #264 蚯蚓
题目描述 本题中,我们将用符号表示对c向下取整,例如:. 蛐蛐国最近蚯蚓成灾了!隔壁跳蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去请神刀手来帮他们消灭蚯蚓. 蛐蛐国里现在共有n只蚯蚓(n为正整数).每只 ...
- 洛谷 P2155 BZOJ 2186 codevs 2301 [SDOI2008]沙拉公主的困惑
题目描述 大富翁国因为通货膨胀,以及假钞泛滥,政府决定推出一项新的政策:现有钞票编号范围为1到N的阶乘,但是,政府只发行编号与M!互质的钞票.房地产第一大户沙拉公主决定预测一下大富翁国现在所有真钞票的 ...
- 洛谷 P2046 BZOJ 2007 海拔(NOI2010)
题目描述 YT市是一个规划良好的城市,城市被东西向和南北向的主干道划分为n×n个区域.简单起见,可以将YT市看作 一个正方形,每一个区域也可看作一个正方形.从而,YT城市中包括(n+1)×(n+1)个 ...
随机推荐
- mysql-5.5 for linux源码安装
mysql-5.5 for linux源码安装 1.使用Yum安装依赖软件包 # yum install -y gcc gcc-c++ gcc-g77 autoconf automake bison ...
- DirectFB编程【转】
本文转载自:http://www.cnblogs.com/274914765qq/p/4358088.html DirectFB编程 一.简介 DirectFB是一个轻量级的提供硬件图形加速,输入设备 ...
- 杂项:Web API
ylbtech-杂项:Web API 今天的web计算平台包含了广泛的功能,其中的大部分均可以通过API(应用程序编程接口)访问. 从简单的社会书签服务del.icio.us,到复杂得多的amazon ...
- z-index 、层叠上下文、层叠级别、z-index失效
一.z-index z-index默认处于非激活状态,只有定位元素(即position:relative/absolute/fixed时)才会被激活. z-index与层叠上下文关联. 当z-inde ...
- js基本功能大全
1.javascript的数组API: //定义数组 var pageIds = new Array(); pageIds.push('A'); 数组长度 pageIds.length; //shif ...
- 函数中的this的四种绑定形式
目录 this的默认绑定 this的隐式绑定 隐式绑定下,作为对象属性的函数,对于对象来说是独立的 在一串对象属性链中,this绑定的是最内层的对象 this的显式绑定:(call和bind方法) n ...
- Appium + python - swipe滑屏操作实例
方法一: from appium import webdriverfrom time import sleep descred_caps = { "platformName":&q ...
- [BZOJ2321,LuoguP1861]星(之)器
丧心病狂的神仙题 丧心病狂的神仙题 丧心病狂的神仙题 显然,不管你怎么移动,答案都是一定的 然后我们很快能联系到物理里面的能量守恒,于是自然地我们要给每个点搞一个势能出来 然后把势能的表达式写出来就可 ...
- Linux安装java jdk、mysql、tomcat
安装javajdk 1.8 检查是否安装 rpm -qa | grep jdk rpm方式安装 下载java1.8 jdk http://download.oracle.com/otn-pub/jav ...
- Android Studio and Gradle安装心得
安装基于Eclipse 的ADT一段时间,感觉确实有很多功能不足,通过网上资料,决定改向AS. AS下载了最新的2.3版本,它不分64位与32位,网上说有单独版是瞎扯蛋.只要启动不同的EXE就行了. ...