码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【leetcode】获取生成数组中的最大值 c++


    题目描述:

    给你一个整数 n 。按下述规则生成一个长度为 n + 1 的数组 nums :

    nums[0] = 0
    nums[1] = 1
    当 2 <= 2 * i <= n 时,nums[2 * i] = nums[i]
    当 2 <= 2 * i + 1 <= n 时,nums[2 * i + 1] = nums[i] + nums[i + 1]
    返回生成数组 nums 中的 最大 值。

    示例 1:

    输入:n = 7
    输出:3
    解释:根据规则:
    nums[0] = 0
    nums[1] = 1
    nums[(1 * 2) = 2] = nums[1] = 1
    nums[(1 * 2) + 1 = 3] = nums[1] + nums[2] = 1 + 1 = 2
    nums[(2 * 2) = 4] = nums[2] = 1
    nums[(2 * 2) + 1 = 5] = nums[2] + nums[3] = 1 + 2 = 3
    nums[(3 * 2) = 6] = nums[3] = 2
    nums[(3 * 2) + 1 = 7] = nums[3] + nums[4] = 2 + 1 = 3
    因此,nums = [0,1,1,2,1,3,2,3],最大值 3

    示例 2:

    输入:n = 2
    输出:1
    解释:根据规则,nums[0]、nums[1] 和 nums[2] 之中的最大值是 1

    示例 3:

    输入:n = 3
    输出:2
    解释:根据规则,nums[0]、nums[1]、nums[2] 和 nums[3] 之中的最大值是 2

    提示:

    0 <= n <= 100

    c++代码:

    class Solution {
    public:
        int getMaximumGenerated(int n) {
            if(n<=1)return n;
            int dp[n+2];
            dp[0]=0;
            dp[1]=1;
            if(n==2)return 1;
            dp[2]=1;
            int max=dp[0];
            for(int i=1;i<=n/2;i++){
                dp[2*i]=dp[i];
                dp[2*i+1]=dp[i]+dp[i+1]; //会越界1个 得到dp[n+1]
            }
            for(int i=0;i<=n;i++){
                if(dp[i]>max)max=dp[i];
            }
            return max;
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20

    题目直接写出递推公式了,直接写代码即可。

    在这里插入图片描述

  • 相关阅读:
    计算机设计大赛心得总结-软件开发组
    人工智能的发展前景如何
    Swin Transformer、ViT作者等共话:好的基础模型是CV 研究者的朴素追求
    编译原理习题两则(龙书,写出语言的正则定义)
    推荐系统-模型:Feed 流推荐
    ProAntd+react+ts表格行点击高亮+表格联动
    Java基础之HashSet和TreeSet
    2023武汉纺织大学计算机考研信息汇总
    java毕业设计项目选题springboot汉赛汽车租赁平台
    【SemiDrive源码分析】【MailBox核间通信】48 - 将RPMSG IPCC RPC 单次传输数据大小修改为 512字节(代码实战部分)
  • 原文地址:https://blog.csdn.net/qq_40315080/article/details/126396996
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号