【代码随想录】【算法训练营】【第31天】 [455]分发饼干 [376]摆动序列 [53]最大子序和

前言

思路及算法思维,指路 代码随想录

题目来自 LeetCode

day 31,放假前的周五,总是令人激动的~

题目详情

[455] 分发饼干

题目描述

455 分发饼干

解题思路

前提:

思路:贪心算法,小饼干优先满足较小胃口。

重点:局部最优解,叠加整体最优解。

代码实现

C语言
排序后,小饼干优先小胃口
c 复制代码
int cmp(void *p1, void *p2)
{
    return (*(int *)p1 > *(int *)p2);
}

int findContentChildren(int* g, int gSize, int* s, int sSize) {
    if ((gSize == 0) || (sSize == 0)) {
        return 0;
    }
    // 排序
    qsort(g, gSize, sizeof(int), cmp);
    qsort(s, sSize, sizeof(int), cmp);

    // 小饼干满足小胃口孩子
    int sLoc = 0;
    int gLoc = 0;
    int count = 0;
    while ((gLoc < gSize) && (sLoc < sSize)) {
        if (g[gLoc] <= s[sLoc]) {
            // 满足胃口,分配
            gLoc++;
            count++;
        }
        sLoc++;
    }
    return count;
}

[376] 摆动序列

题目描述

376 摆动序列

解题思路

前提:差值正负交替出现,即出现山峰或低谷

思路:判断峰值的个数

重点:注意平坡,尤其是首尾位置,影响序列长度。

代码实现

C语言
寻找峰值个数,注意平坡
c 复制代码
int wiggleMaxLength(int* nums, int numsSize){
	// 初始化为1,默认首位前为平坡
    int length = 1;
    int prediff = 0;
    int curdiff = 0;
    for (int i = 0; i < numsSize - 1; i++) {
        int curdiff = nums[i + 1] - nums[i]; 
        // 判断是否为符合要求的山峰或低谷
        if (((prediff >= 0) && (curdiff < 0)) || ((prediff <= 0) && (curdiff > 0))) {
            length++;
            // 出现峰值时更新prediff
            prediff = curdiff;
        }
    }
    return length;
}

[53] 最大子序和

题目描述

53 最大子序和

解题思路

前提:连续子数组的和的最大值

思路:负数与任何数值相加,只会使值变的更小,所以当当前和为负数时,抛弃该和,重新计算。

重点:贪心算法思维。

代码实现

C语言
连续和为负数时,抛弃当前连续子数组和
c 复制代码
int maxSubArray(int* nums, int numsSize) {
    int sum = 0;
    int slow = 0;
    int fast = 0;
    int maxSum = -10001;
    while (fast < numsSize) {
        // 连续和为负数时,抛弃当前连续子数组和
        if (sum < 0) {
            sum = 0;
        }
        sum += nums[fast];
        // 取最大和
        if (sum > maxSum) {
            maxSum = sum;
        }
        fast++;
    }
    return maxSum;
}

今日收获

  1. 贪心算法思维方式。
相关推荐
爱吃生蚝的于勒2 小时前
C语言内存函数
c语言·开发语言·数据结构·c++·学习·算法
ChoSeitaku7 小时前
链表循环及差集相关算法题|判断循环双链表是否对称|两循环单链表合并成循环链表|使双向循环链表有序|单循环链表改双向循环链表|两链表的差集(C)
c语言·算法·链表
Fuxiao___7 小时前
不使用递归的决策树生成算法
算法
我爱工作&工作love我7 小时前
1435:【例题3】曲线 一本通 代替三分
c++·算法
白-胖-子8 小时前
【蓝桥等考C++真题】蓝桥杯等级考试C++组第13级L13真题原题(含答案)-统计数字
开发语言·c++·算法·蓝桥杯·等考·13级
workflower8 小时前
数据结构练习题和答案
数据结构·算法·链表·线性回归
好睡凯8 小时前
c++写一个死锁并且自己解锁
开发语言·c++·算法
Sunyanhui18 小时前
力扣 二叉树的直径-543
算法·leetcode·职场和发展
一个不喜欢and不会代码的码农8 小时前
力扣105:从先序和中序序列构造二叉树
数据结构·算法·leetcode
前端郭德纲8 小时前
浏览器是加载ES6模块的?
javascript·算法