鱼C论坛

 找回密码
 立即注册
查看: 2438|回复: 6

求该问题时间复杂度最小的算法

[复制链接]
发表于 2021-9-16 11:01:46 From FishC Mobile | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
给出项数为 n 的整数数列 {ai},下标i从1开始。
定义函数 f(i)
f(i) 代表数列中第 i个元素之后第一个大于ai的元素的下标,即f(i)=min { j }, aj>ai,i<j<=n
若不存在,则 f(i)=0
试求出 f(1)…f(n)
输入格式
第一行一个正整数
n。
第二行
n个正整数 a1…an
输出格式
一行 n个整数 f(1)…f(n)
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-9-16 15:32:49 | 显示全部楼层
c++有个lower_bound函数(不确定是不是最低复杂度)
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-9-16 15:58:05 | 显示全部楼层
monkey-D 发表于 2021-9-16 15:32
c++有个lower_bound函数(不确定是不是最低复杂度)

可是这个lower_bound要求数组排序啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-9-16 17:20:10 | 显示全部楼层
本帖最后由 jhq999 于 2021-9-16 17:52 编辑

{1,2,0,8,2}
f(1)=2;f(2)=4;f(3)=4;f(4)=0;f(5)=0
我理解的对吗?

  1. #include <stdio.h>

  2. int main()
  3. {
  4.        int i=0,j=0,n=0,m=0,*val,*f;
  5. scanf("%d",&n);
  6. getchar();
  7. val=new int[n];
  8. f=new int[n];
  9. i=0;
  10. while(i<n)
  11. {
  12. scanf("%d",(val+i));
  13. i++;
  14. }
  15. m=0;
  16. for(i=0;i<n;i++)
  17. {
  18.         for (j = i+1; j < n; j++)
  19.         {
  20.                 if (val[j]>val[i])
  21.                 {
  22.                         break;
  23.                 }
  24.         }
  25.         if(j==n)
  26.                 f[i]=0;
  27.         else
  28.         {
  29.                 f[i]=j+1;
  30.         }
  31. }
  32. for (i = 0; i < n; i++)
  33. {
  34.         printf("f(%d)=%d,",i+1,f[i]);
  35. }
  36. delete[] val,f;
  37.     return 0;
  38. }
复制代码

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-9-16 20:55:57 | 显示全部楼层
jhq999 发表于 2021-9-16 17:20
{1,2,0,8,2}
f(1)=2;f(2)=4;f(3)=4;f(4)=0;f(5)=0
我理解的对吗?

理解的是对的  但就是想找一种时间复杂度 小于 O(n2)的算法
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-9-16 21:39:33 | 显示全部楼层
1248762042 发表于 2021-9-16 20:55
理解的是对的  但就是想找一种时间复杂度 小于 O(n2)的算法
  1. int main()
  2. {
  3.         int i=0,j=0,n=0,m=0,*val,*f;
  4.         scanf("%d",&n);
  5.         getchar();
  6.         val=new int[n];
  7.         f=new int[n];
  8.         i=0;
  9.         while(i<n)
  10.         {
  11.                 scanf("%d",(val+i));
  12.                 i++;
  13.         }
  14.         m=0;
  15.         for(i=0;i<n;i++)
  16.         {
  17.                 if (i>=m)
  18.                 {


  19.                         for (j = i+1; j < n; j++)
  20.                         {
  21.                                 if (val[j]>val[i])
  22.                                 {
  23.                                         break;
  24.                                 }
  25.                         }
  26.                         if(j==n)
  27.                                 f[i]=0;
  28.                         else
  29.                         {
  30.                                 m=j;
  31.                                 f[i]=j+1;
  32.                         }
  33.                 }
  34.                 else
  35.                 {
  36.                         f[i]=m+1;
  37.                 }
  38.         }
  39.         for (i = 0; i < n; i++)
  40.         {
  41.                 printf("f(%d)=%d,",i+1,f[i]);
  42.         }
  43.         delete[] val,f;
  44.         return 0;


  45. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-9-23 11:54:51 | 显示全部楼层

开卷有益,多多益善····
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-26 10:23

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表