力扣上C语言编程题:最大子数组和(涉及数组)

一. 简介

本文记录力扣网上涉及数组方面的编程题,主要以 C语言实现。

二. 力扣上C语言编程题:最大子数组和

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

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

提示:

  • 1 <= nums.length <= 105
  • -104 <= nums[i] <= 104

示例1:

输入: nums = [-2,1,-3,4,-1,2,1,-5,4]

输出:6

解释:连续子数组为 [4, -1, 2, 1] 的和最大,其和为 6

示例2:

输入: nums = [1]

输出:1

解题思路:

使用贪心解法。什么是贪心解法?

"贪心解法"(Greedy Algorithm)是一种在算法设计中常用的策略,它通过每一步选择当前状态下局部最优解(即最有利的选择),期望通过这样的方式最终得到全局最优解。

贪心算法的核心是:每一步都做出局部最优的选择,希望通过局部最优解达到全局最优解。

**局部最优:**当前 "连续和" 为负数时立刻放弃,从下一个元素重新计算 "连续和" ,因为负数加上下一个元素 "连续和"只会越来越小。

**全局最优:**选取最大"连续和"

具体方法:

(1) 遍历数组,如果前面数组和小于 0,则从 nums[i] 开始重新新一轮求和计算;(因为数组和为负数时,再加下一个元素,只会让总和变小,即都会加重负担);

(2) 每次记录数组和的最大值;

C代码实现如下:

复制代码
int maxSubArray(int* nums, int numsSize) {
    if ((!nums) || (numsSize == 0)) {
        return -1;
    }

    int i = 0;
    int prev_sums = nums[0];
    int max_sums = nums[0];

    //下标从1开始遍历
    for(i = 1; i < numsSize; i++) { 
        if(prev_sums < 0) { //如果前面数组和小于0,则从nums[i]重新开始计数
            prev_sums = nums[i];
        }
        else { //前面数组和 >=0,则继续加nums[i]
            prev_sums = prev_sums + nums[i];
        }
        //每次更新子数组和的最大值
        if(prev_sums > max_sums) {
            max_sums = prev_sums;
        }
    }

    return max_sums;
}
相关推荐
无极低码1 小时前
ecGlypher新手安装分步指南(标准化流程)
人工智能·算法·自然语言处理·大模型·rag
爱编码的小八嘎2 小时前
C语言完美演绎4-7
c语言
软件算法开发2 小时前
基于海象优化算法的LSTM网络模型(WOA-LSTM)的一维时间序列预测matlab仿真
算法·matlab·lstm·一维时间序列预测·woa-lstm·海象优化
superior tigre2 小时前
22 括号生成
算法·深度优先
炘爚3 小时前
C语言(文件操作)
c语言·开发语言
努力也学不会java3 小时前
【缓存算法】一篇文章带你彻底搞懂面试高频题LRU/LFU
java·数据结构·人工智能·算法·缓存·面试
W.D.小糊涂4 小时前
gpu服务器安装windows+ubuntu24.04双系统
c语言·开发语言·数据库
旖-旎4 小时前
二分查找(x的平方根)(4)
c++·算法·二分查找·力扣·双指针
ECT-OS-JiuHuaShan4 小时前
朱梁万有递归元定理,重构《易经》
算法·重构
智者知已应修善业5 小时前
【51单片机独立按键控制数码管移动反向,2片74CH573/74CH273段和位,按键按下保持原状态】2023-3-25
经验分享·笔记·单片机·嵌入式硬件·算法·51单片机