BZOJ 4547: Hdu5171 小奇的集合
Sol
首先,考虑这个要怎么搞...让总和最大的方法就是选出当前集合中最大的两个数相加放入集合中就可以了,证明非常简单,当前集合的和为x,它的和只会一直往后增加,所以只需要找到最大的两个数的和加入便是最佳答案.知道了这个以后,手动递推一下就是一个斐波拉契数列.
然后斐波拉契数列数列自然可以矩乘,但是矩阵乘法不能解决负数斐波拉契问题.而且,一正一负就不是斐波拉契数列的递推了.递推应该是这个样子.
\(F_2=F_1+F_0,F_3=F_2+F_1=F_1+F_1+F_0...F_n=F_1*(n-1)+F_0\)
所以我们就可以直接 \(O(1)\) 得到需要进行多少次操作使得出现两个正数,原来的 \(F_1\) 就已经是一个正数了,所以操作数为 \(\left \lfloor -F_0/F_1 \right \rfloor +1\) 求和用等差数列求和公式,剩下的直接矩乘.
剩下的问题就是斐波拉契数列求和的问题了,我们知道斐波拉契数列前n项和 \(\sum_{i=0}^{n}F_i=F_{n+2}-1\) 虽然这个前两项并不是1,但是可以得到相似的结论 \(\sum_{i=0}^{n}F_i=F_{n+2}-F_1\) .
在这里我给出证明,证明也很简单,数学归纳法.
证明: \(n=0\) 时显然成立, \(F_0=F_2-F_1\) 移项一下就是递推式
当 \(n>0\) 时,假设有 \(\sum_{i=0}^{n}F_i=F_{n+2}-F_1\)
只需要证明在 \(n+1\) 时同样成立即可.
\(\sum_{i=0}^{n+1}F_i=\sum_{i=0}^{n}F_i +F_{n+1}=F_{n+2}-F_1+F_{n+1}=F_{n+3}-F_1\)
即在 \(n+1\) 处依然成立,证毕.
PS:当然这个也可以构造一个矩阵同时记录前缀和即可.
PS:我代码码风改了改...应该可以还算可阅吧...QAQ
Code
/**************************************************************
Problem: 4547
User: BeiYu
Language: C++
Result: Accepted
Time:324 ms
Memory:2076 kb
****************************************************************/ #include<cstdio>
#include<vector>
#include<algorithm>
#include<iostream>
using namespace std; #define debug(a) cout<<#a<<"="<<a<<endl
typedef long long LL;
typedef vector<LL> Vec;
typedef vector<Vec> Mat;
const LL Mo = 10000007;
const int N = 100005; Mat operator * (const Mat &A,const Mat &B){
Mat C(2,Vec(2));
for(int i=0;i<2;i++) for(int j=0;j<2;j++) for(int k=0;k<2;k++)
C[i][j]=(C[i][j]+A[i][k]*B[k][j])%Mo;
return C;
}
Mat operator ^ (Mat A,LL b){
Mat res(2,Vec(2));
res[0][0]=1,res[0][1]=0,res[1][0]=0,res[1][1]=1;
for(;b;b>>=1,A=A*A){
if(b&1) res=res*A;
}return res;
} LL n,k;LL a[N];
inline LL in(LL x=0,char ch=getchar(),int v=1){
while(ch>'9'||ch<'0') v=ch=='-'?-1:1,ch=getchar();
while(ch>='0'&&ch<='9') x=(x<<3)+(x<<1)+ch-'0',ch=getchar();
return x*v;
}
int main(){
n=in(),k=in();
for(int i=1;i<=n;i++) a[i]=in();
sort(a+1,a+n+1);
LL tmp,f0=a[n-1],f1=a[n],ans=0;
for(int i=1;i<n-1;i++) ans=(ans+a[i]+Mo)%Mo;
if(f0<0){
tmp=-f0/f1+1;
if(tmp<=k){
k-=tmp,ans=(ans+(f0+f0+f1*(tmp-1))*(tmp)/2%Mo)%Mo;
f0=(f0+f1*tmp%Mo)%Mo;
if(f0>f1) swap(f0,f1);
}
}
Mat F(2,Vec(2));F[0][0]=0,F[0][1]=1,F[1][0]=1,F[1][1]=1;
Mat Fn=F^(k+2);
ans=(ans+f0*Fn[0][1]%Mo+f1*Fn[1][1]%Mo)%Mo;
ans=(ans-f1+Mo)%Mo;
printf("%lld\n",ans);
return 0;
}
BZOJ 4547: Hdu5171 小奇的集合的更多相关文章
- bzoj4547: Hdu5171 小奇的集合(矩阵乘法)
4547: Hdu5171 小奇的集合 题目:传送门 题解: 做一波大佬们的坑...ORZ 不得不说,我觉得矩阵很简单啊,就一个3*3的(直接看代码吧) 给个递推柿纸:f[i]=f[i-1]+max1 ...
- BZOJ4547 Hdu5171 小奇的集合 【矩阵快速幂优化递推】
BZOJ4547 Hdu5171 小奇的集合 Description 有一个大小为n的可重集S,小奇每次操作可以加入一个数a+b(a,b均属于S),求k次操作后它可获得的S的和的最大值.(数据保证这个 ...
- 【BZOJ4547】Hdu5171 小奇的集合 矩阵乘法
[BZOJ4547]Hdu5171 小奇的集合 Description 有一个大小为n的可重集S,小奇每次操作可以加入一个数a+b(a,b均属于S),求k次操作后它可获得的S的和的最大值.(数据保证这 ...
- BZOJ4547 Hdu5171 小奇的集合
题意 有一个大小为n的可重集S,小奇每次操作可以加入一个数a+b(a,b均属于S),求k次操作后它可获得的S的和的最大值.(数据保证这个值为非负数) 对于100%的数据,有 n<=10^5,k& ...
- 【BZOJ-4547】小奇的集合 矩阵乘法 + 递推
4547: Hdu5171 小奇的集合 Time Limit: 2 Sec Memory Limit: 256 MBSubmit: 175 Solved: 85[Submit][Status][D ...
- bzoj 4547 小奇的集合
Description 有一个大小为n的可重集S,小奇每次操作可以加入一个数a+b(a,b均属于S),求k次操作后它可获得的S的和的最大 值.(数据保证这个值为非负数) Input 第一行有两个整数n ...
- 【BZOJ 4547】【HDU 5157】小奇的集合
http://www.lydsy.com/JudgeOnline/problem.php?id=4547 本蒟蒻并不会矩乘求Fibonacci数列前缀和,所以果断分块打表,常数竟然比矩乘要小! PS: ...
- bzoj4547 小奇的集合
当序列中最大和次大都是负数的时候,其相加会是一个更小的负数,因此答案为(Σai)+(m1+m2)*k,如果最大是正数次大是负数,那么一直相加直到两个数都为正数,当最大和次大都是正数时,做一下矩阵乘法即 ...
- [HDU517] 小奇的集合
题目链接 显然有贪心每次选择最大的两个数来做. 于是暴力地把最大的两个数调整到非负(暴力次数不超过1e5),接下来使用矩阵乘法即可. \[ \begin{pmatrix} B'\\S'\\T' \en ...
随机推荐
- CSS学习笔记——响应式布局
响应式布局 响应式布局是现在很流行的一个设计理念,随着移动互联网的盛行,为解决如今各式各样的浏览器分辨率以及不同移动设备的显示效果,设计师提出了响应式布局的设计方案.所谓的响应式布局,就是一个网站能够 ...
- 在64位系统上不能安装Matlab notebook的解决方案
在64位系统上不能安装Matlab notebook的解决方案 过程分解 第一步:安装好matlab(附:Matalab R2015a界面) 第二步:在matlab中执行命令 >>note ...
- System.BadImageFormatException: Could not load file or assembly
C:\Windows\Microsoft.NET\Framework64\v4.0.30319>InstallUtil.exe C:\_PRODUKCIJA\Debug\DynamicHtmlT ...
- jQuery/js 正则收集(邮件验证、)
var reg = /^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/; //验证邮箱的正则表达式if( ...
- 使用VMware 安装Linux CentOS7
访问百度经验 http://jingyan.baidu.com/article/eae0782787b4c01fec548535.html 安装无忧..
- Web启动服务器上的某一个服务
情景是这样的.. 网页打开一个数据列表..数据要求实时从其他多个平台上获取.. 所以就有了一个Web页面..还有个WinService的服务来定时获取这些数据... 问题来了.. 发现Service有 ...
- Mac终端Terminal调用Sublime Text
Sublime Text 本身提供了命令行工具, 只需要在 Terminal 中输入以下内容就行了 sudo ln -s /Applications/Sublime\ Text.app/Content ...
- Autolayout学习(1)-了解Autoreszing
1. 为什么要有Autoreszing? 在Xcode6之前,如果定义了下面的一个布局,同时运行在不同尺寸设备下会显示不同的效果. (iPhone6-4.7inch) (iPhone5s-4inch) ...
- PHP单一入口apache配置和去除index.php
index : index在互联网上表示网站的默认主页. 一般为 index.html index.htm index.asp index.php: 另外的默认主页也多用default.html;de ...
- 浙大PAT-1001
1001. 害死人不偿命的(3n+1)猜想 (15) 卡拉兹(Callatz)猜想: 对任何一个自然数n,如果它是偶数,那么把它砍掉一半:如果它是奇数,那么把(3n+1)砍掉一半.这样一直反复砍下去, ...