题意

  1. 小明有一个不降序列(f1),f2),f3),……),fk)代表在这个序列中大小是k的有fk)个。我们规定fn)的前12项如下图。

n 1 2 3 4 5 6 7 8 9 10 11 12

f(n) 1 2 2 3 3 4 4 4 5 5 5 6

现在给你一个n,你知道f(n)是多少吗?

多组测试数据

每组一个n(1<=n<=2000,000,000)。

###法一:正常情况下想的到。

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<algorithm>
  4. using namespace std;
  5. const long long maxn=20000000;
  6. int f[maxn];
  7. int main ()
  8. {
  9. int nn,i;
  10. long long j;
  11. f[1]=1;
  12. f[2]=2;
  13. f[3]=2;
  14. j=3;
  15. for(i=3;j<=maxn-3;i++)
  16. {
  17. nn=f[i];
  18. while(nn--&&j<=maxn)
  19. {
  20. f[++j]=i;
  21. }
  22. }
  23. int n;
  24. while(~scanf("%d",&n))
  25. {
  26. int ans=0,i;
  27. for(i=1;ans<n;i++)
  28. {
  29. ans+=f[i];
  30. }
  31. printf("%d\n",i-1);
  32. }
  33. return 0;
  34. }

法二:正常情况下想不到

  1. 因为n的最大范围是20亿,显然不能数组保存,而且时间也不允许,也很难发现什么规律。我们可以换个角度,既然要找的是f[n]的值,那么我们把f[x]=i时的最大x记录为 d[i] = x;
  2. d[1] = 1
  3. d[2] = 3
  4. d[3] = 5
  5. d[4] = 8
  6. d[5] = 11

仔细推敲不难发现规律

从3起,d[i] = d[i-1] + find(i); find(i) = min(k) 当d[k]>=i时

find(i)也就是d数组中大于等于i的一项的最小值的下标。

  1. #include<cstdio>
  2. #include<iostream>
  3. #include<algorithm>
  4. #include<cstring>
  5. using namespace std;
  6. typedef long long LL;
  7. const int maxn=680000;
  8. LL fuck[maxn];
  9. int i;
  10. int Find(int l,int r,int key)
  11. {
  12. int mid;
  13. while(l<r)
  14. {
  15. mid=(l+r)/2;
  16. if(fuck[mid]<key)
  17. l=mid+1;
  18. else
  19. r=mid;
  20. }
  21. return l;
  22. }
  23. void init()
  24. {
  25. fuck[1]=1;fuck[2]=3;
  26. for(i=3;i<=673365;i++){
  27. fuck[i]=fuck[i-1]+Find(1,i-1,i);
  28. }
  29. }
  30. int main ()
  31. {
  32. int n;init();
  33. while(~scanf("%d",&n))
  34. printf("%d\n",Find(1,i,n));
  35. return 0;
  36. }

STL的魅力

  1. #include<cstdio>
  2. #include<iostream>
  3. #include<algorithm>
  4. #include<cstring>
  5. using namespace std;
  6. typedef long long LL;
  7. const int maxn=680000;
  8. LL fuck[maxn];
  9. int i;
  10. void init()
  11. {
  12. fuck[1]=1;fuck[2]=3;
  13. for(i=3;i<=673365;i++){
  14. fuck[i]=fuck[i-1]+(lower_bound(fuck+1, fuck+i-1,i)-fuck);
  15. }
  16. }
  17. int main ()
  18. {
  19. int n;init();
  20. while(~scanf("%d",&n))
  21. printf("%ld\n",(lower_bound(fuck+1, fuck+i,n)-fuck));
  22. return 0;
  23. }

F(k)<(维护+枚举)\(找规律+递推+枚举)>的更多相关文章

  1. codeforces D. Queue 找规律+递推

    题目链接: http://codeforces.com/problemset/problem/353/D?mobile=true H. Queue time limit per test 1 seco ...

  2. BZOJ1002:[FJOI2007]轮状病毒(找规律,递推)

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

  3. HDU-2045 不容易系列之(3)—— LELE的RPG难题 找规律&递推

    题目链接:https://cn.vjudge.net/problem/HDU-2045 找规律 代码 #include <cstdio> long long num[51][2]; int ...

  4. 2018南京区域赛G题 Pyramid——找规律&&递推

    先手动推出前10项,再上BM板子求出递推式 $A_n = 5A_{n-1} - 10A_{n-2} + 10A_{n-3} - 5A_{n-4} + A_{n-5}$,根据特征根理论可求出特征方程 $ ...

  5. HDU-2050 折线分割平面 找规律&递推

    题目链接:https://cn.vjudge.net/problem/HDU-2050 题意 算了吧,中文题不解释了 我们看到过很多直线分割平面的题目,今天的这个题目稍微有些变化,我们要求的是n条折线 ...

  6. ACM-ICPC 2018 徐州赛区网络预赛 A.Hard to prepare 【规律递推】

    任意门:https://nanti.jisuanke.com/t/31453 A.Hard to prepare After Incident, a feast is usually held in ...

  7. POJ 2229 sumset ( 完全背包 || 规律递推DP )

    题意 : 给出一个数 n ,问如果使用 2 的幂的和来组成这个数 n 有多少种不同的方案? 分析 :  完全背包解法 将问题抽象==>有重量分别为 2^0.2^1.2^2…2^k 的物品且每种物 ...

  8. 【bzoj4318】【OSU!】期望dp——维护多个期望值递推

    [pixiv] https://www.pixiv.net/member_illust.php?mode=medium&illust_id=62369739 Description osu 是 ...

  9. ACM学习历程—NPU 2015年陕西省程序设计竞赛网络预赛(正式赛)F题 和谐的比赛(递推)

    Description 今天西工大举办了一场比赛总共有m+n人,但是有m人比较懒没带电脑,另外的n个人带了电脑.不幸的是,今天机房的电脑全坏了只能用带的电脑,一台电脑最多两人公用,确保n>=m. ...

随机推荐

  1. 自己写deque

    //deque /* what is a deque? In Chinese, it's called "双端队列". It's different from a queue. I ...

  2. Struts入门学习(一)

    刚开始学习框架的时候感觉很简单,都是用到javaEE的相关框架,自己就想研究源码,但是学了很久之后毫无头绪,所以还是扎扎实实学好Struts毕竟框架做起来要比自己写javaEE要简单,下面我们就来一步 ...

  3. UITextField的属性设置

    1.背景颜色 field.backgoundColor = [UIColor redColor]; 2.设置field文字 field.text = @"输入文字"; 3.设置fi ...

  4. 免费开源的boostrap模板

    百度查不到,奶奶的,百度好多国外技术类文章的都查不到 https://colorlib.com/wp/free-html5-admin-dashboard-templates/ 有没有FQ软件介绍呀?

  5. DirectShow音频采集声音不连续问题分析与解决办法经验总结

    最近广州大雨不断,并且多数无前兆,突然就来场大雨,给同学们降降温,说来本也是好事,但有时候下的真不是时候,最近这段时间都是即将下班了,大雨就来了,昨晚快下班前又出现了大雨,北方人总爱忘带雨伞,这不就被 ...

  6. NSURL访问项目中的文件

    最近在研究视频处理,具体为:将一个mp4文件,拖入项目工程中,通过url访问文件. 开始代码如下: NSString *path = [[NSBundle mainBundle]pathForReso ...

  7. 一个初学者的辛酸路程-初识Python-1

    前言 很喜欢的一句话,与诸位共勉. 人的一切痛苦,本质上都是对自己无能的愤怒----王小波. 初识Python 一.它的爸爸是谁 首先,我们需要认识下面这位人物. 他是Python的创始人,吉多范罗苏 ...

  8. javascript performence

    1.将脚本放在底部 javascript是阻塞式的加载,如果先加载脚本,后面的dom都没有办法进行渲染,页面会是一片空白: 采用无阻塞下载javascript a.使用<script>标签 ...

  9. php学习的第8天

    晚上老师布置啦17题算数问题的作业 我一看 感觉挺容易的 动手就开始做啦起来 不知不觉也9点多啊 终于做好前部题目 发现这我3个月前也遇到类似的题目 那是我还一题都做一题用上1个钟左右 好多也做不出 ...

  10. 线程池Executors探究

    线程池用到的类在java.util.concurrent包下,核心类是Executors,通过其不同的几个方法可产生不同的线程池. 1.生成固定大小的线程池 public static Executo ...