Codeforces 633D
题意:
给定n,和一个长度为n的序列。
让你在这n个数中找长度尽可能长的fib数列。
思路:
这题的数字是在1e9范围内的,所以最长的可能存在的fib数列官方的解释是90左右。有一种情况除外,就是0的个数比较多的情况下。
而决定fib数列的是开头的两个数字,以及顺序,介于n是1000的范围我们就可以暴力开头的两个数字啦。这题要注意0的情况,如果整个序列都是0的话,那么复杂度就是1e9了,所以本人先unique了一下,然后每次从unique完的数组里边取材,这样就避免了0的问题同时也某些程度上减少了复杂度。需要注意的是unique完了之后有可能本身和本身作为fib数列的前两个,因为原始序列中可能存在相同的。
坑点:
这题我一开始的思路是记忆话搜索,但是...不能保证记录的那个序列和原来的序列没有在数组中重复取材。记住fib的特性啊啊啊啊
编号和题目中的序列搞混了,WA了两发。
#include<bits/stdc++.h>
using namespace std;
int jilu[],aft[];
bool vis[];
int n;
int ans=;
void dfs(int bf,int sum,int step){
int id=lower_bound(jilu,jilu+n,sum)-jilu;
if(id>=n||(id==&&jilu[]!=sum)){
if(ans<step)
ans=step;
}
else if(!vis[id]){
if(jilu[id]==sum){
vis[id]=;
dfs(sum,bf+sum,step+);
}
else{
if(ans<step)
ans=step;
}
}
else{
while(id<n&&vis[id]&&jilu[id]==sum){
id++;
}
if(id>=n||vis[id]||jilu[id]!=sum){
if(ans<step)
ans=step;
}
else{
vis[id]=;
dfs(sum,sum+bf,step+);
}
}
}
int main()
{
scanf("%d",&n);
for(int i=;i<n;i++){
scanf("%d",&jilu[i]);
aft[i]=jilu[i];
}
sort(aft,aft+n);
sort(jilu,jilu+n);
int num=unique(aft,aft+n)-aft;
for(int i=;i<num;i++){
for(int j=i;j<num;j++){
memset(vis,,sizeof(vis));
if(i==j){
int id=lower_bound(jilu,jilu+n,aft[i])-jilu;
if(id+<n&&jilu[id]==jilu[id+]){
vis[id]=vis[id+]=;
dfs(jilu[id],jilu[id]+jilu[id],);
}
}
else{
int id1,id2;
id1=lower_bound(jilu,jilu+n,aft[i])-jilu;
id2=lower_bound(jilu,jilu+n,aft[j])-jilu;
vis[id1]=vis[id2]=;
dfs(jilu[id1],jilu[id2]+jilu[id1],);
memset(vis,,sizeof(vis));
vis[id1]=vis[id2]=;
dfs(jilu[id2],jilu[id2]+jilu[id1],);
}
}
}
printf("%d\n",ans);
}
Codeforces 633D的更多相关文章
- Codeforces 633D Fibonacci-ish 暴力
题意:1000个元素,每个元素的大小-1e9<=a[i]<=1e9,然后让你重新安排这些元素的位置 获得最长的前缀斐波那契数列 分析:枚举第一个元素和第二个元素,因为在题目元素的范围内,最 ...
- codeforces 633D - Fibonacci-ish 离散化 + 二分查询
Fibonacci-ish Yash has recently learnt about the Fibonacci sequence and is very excited about it. He ...
- codeforces 633D D. Fibonacci-ish(dfs+暴力+map)
D. Fibonacci-ish time limit per test 3 seconds memory limit per test 512 megabytes input standard in ...
- CodeForces - 633D Fibonacci-ish 大数标记map+pair的使用
Fibonacci-ish Yash has recently learnt about the Fibonacci sequence and is very excited about it. He ...
- python爬虫学习(5) —— 扒一下codeforces题面
上一次我们拿学校的URP做了个小小的demo.... 其实我们还可以把每个学生的证件照爬下来做成一个证件照校花校草评比 另外也可以写一个物理实验自动选课... 但是出于多种原因,,还是绕开这些敏感话题 ...
- 【Codeforces 738D】Sea Battle(贪心)
http://codeforces.com/contest/738/problem/D Galya is playing one-dimensional Sea Battle on a 1 × n g ...
- 【Codeforces 738C】Road to Cinema
http://codeforces.com/contest/738/problem/C Vasya is currently at a car rental service, and he wants ...
- 【Codeforces 738A】Interview with Oleg
http://codeforces.com/contest/738/problem/A Polycarp has interviewed Oleg and has written the interv ...
- CodeForces - 662A Gambling Nim
http://codeforces.com/problemset/problem/662/A 题目大意: 给定n(n <= 500000)张卡片,每张卡片的两个面都写有数字,每个面都有0.5的概 ...
随机推荐
- js事件源window.event.srcElement兼容性写法
<html> <body> <p>一个好处就是 我想让body(或其他元素内)的某些对象响应事件 就不用挨个儿去写 只要在外层上写一个 然后检查event.srcE ...
- hadoop spark学习笔记
http://www.csdn.net/article/2015-06-08/2824889 hive:是基于Hadoop的一个数据仓库工具,可以将结构化的数据文件映射为一张数据库表,并提供简单的sq ...
- java序列化---转
Java 序列化Serializable详解(附详细例子) 1.什么是序列化和反序列化Serialization(序列化)是一种将对象以一连串的字节描述的过程:反序列化deserialization是 ...
- VBA excel中表示列的字母换成数字
出自这里 数字转列标: Split(Cells(1,).Address(1,0),"$")(0) '将1-256替换红色的1就可以 Cells(1, a) 选中对应的第一行第 ...
- 一些C#预处理器指令
像C语言一样,C#有一些预处理器指令的命令.例如,#if#end if,#define等,所谓这些命令是指不会转化为可执行代码中的一些命令,只是在编译的过程中起作用.下面简要介绍一下:1 .#defi ...
- [摘]Hibernate查询事务必要性
背景: 添加事务与否都不影响Hibernate的查询操作. 问题: 查询操作是否有必要添加事务? 答案1: Hibernate官方手册上建议任何操作(增删改查)都需要添加事务. 答案2: robbin ...
- (转)如何在eclipse的配置文件里指定jdk路径
本文转载自:http://songguoliang.iteye.com/blog/1752519 运行eclipse时报如下错误: 在eclipse的配置文件里指定jdk路径,只需在eclipse的配 ...
- 一个问题提交的实例(js原生动画,原生ajax,js引用加参数)
document.writeln("<div id=\"tanchuangwai\" class=\"tanchuangwai\" style= ...
- bzoj2152 聪聪可可
Description 聪聪和可可是兄弟俩,他们俩经常为了一些琐事打起来,例如家中只剩下最后一根冰棍而两人都想吃.两个人都想玩儿电脑(可是他们家只有一台电脑)……遇到这种问题,一般情况下石头剪刀布就好 ...
- Add LUN to ASM in Linux
# Create new LUN for Linux in the AMS2100 # echo "- - -" >/sys/class/scsi_host/host3/sc ...