码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 53. Maximum Subarray最大子数组和


    Given an integer array nums, find the contiguous subarray (containing at least one number) which has the largest sum and return its sum.

    给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。

    A subarray is a contiguous part of an array.

    子数组 是数组中的一个连续部分。

    Example 1:示例 1:

    Input: nums = [-2,1,-3,4,-1,2,1,-5,4]
    Output: 6
    Explanation: [4,-1,2,1] has the largest sum = 6.


    Example 2:示例 2:

    Input: nums = [1]
    Output: 1


    Example 3:示例 3:

    Input: nums = [5,4,-1,7,8]
    Output: 23
     

    Constraints:提示:

    1 <= nums.length <= 10^{5}
    -10^{4} <= nums[i] <= 10^{4}

     

    Follow up: If you have figured out the O(n) solution, try coding another solution using the divide and conquer approach, which is more subtle.

    进阶:如果你已经实现复杂度为 O(n) 的解法,尝试使用更为精妙的 分治法 求解。

    C语言(超出时间限制)

    1. int maxSubArray(int* nums, int numsSize){
    2. int max=-10000,temp;
    3. for(int i=0;i
    4. {
    5. temp=nums[i];
    6. if(max
    7. {
    8. max=nums[i];
    9. }
    10. for(int j=i+1;j
    11. {
    12. temp+=nums[j];
    13. if(max
    14. {
    15. max=temp;
    16. }
    17. }
    18. }
    19. return max;
    20. }

    C语言:

    1. int maxSubArray(int* nums, int numsSize){
    2. int cur=nums[0];
    3. int max=nums[0];
    4. for(int i=1;i
    5. {
    6. if(cur+nums[i]>nums[i])
    7. {
    8. cur+=nums[i];
    9. }
    10. else
    11. {
    12. cur=nums[i];
    13. }
    14. if(max
    15. {
    16. max=cur;
    17. }
    18. }
    19. return max;
    20. }

    执行结果:通过

    执行用时:96 ms, 在所有 C 提交中击败了65.95%的用户

    内存消耗:11.9 MB, 在所有 C 提交中击败了94.63%的用户

    通过测试用例:209 / 209

    C语言:

    1. int maxSubArray(int* nums, int numsSize){
    2. int cur=0;
    3. int max=INT_MIN;
    4. for(int i=0;i
    5. {
    6. if(cur<=0)
    7. cur=nums[i];
    8. else
    9. cur+=nums[i];
    10. if(cur>max)
    11. max=cur;
    12. }
    13. return max;
    14. }

    执行结果:通过

    执行用时:88 ms, 在所有 C 提交中击败了97.43%的用户

    内存消耗:12.3 MB, 在所有 C 提交中击败了8.30%的用户

    通过测试用例:209 / 209

  • 相关阅读:
    力扣:119. 杨辉三角 II(Python3)
    Mysql创建账号并且赋予权限
    PostCSS概述
    VUE状态持久化,储存动态路由
    联通研究院霍龙社博士深度解析“AI项目到底适不适合开源”
    谷歌版ChatGPT与旗下邮箱、视频、地图等,实现全面集成!
    Java版企业电子招标采购系统源码—企业战略布局下的采购寻源
    【外汇天眼】很多交易高手都容易忽视的问题:“路径依赖”!
    Java进公司首先要做的准备工作-maven、idea、Tomcat安装和配置
    【计算机网络笔记】路由算法之链路状态路由算法
  • 原文地址:https://blog.csdn.net/DXB2021/article/details/126008701
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号