【代码随想录】【算法训练营】【第35天】 [1005]K次取反后最大化的数组和 [134]加油站 [135]分发糖果

前言

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

题目来自 LeetCode

day 35,连休两天~

题目详情

[1005] K次取反后最大化的数组和

题目描述

1005 K次取反后最大化的数组和

解题思路

前提:数组

思路:优先负数取反,未取到k次, 两两抵消后,将绝对值最小的正值取反。

重点:两次贪心。

代码实现

C语言
数组大小排序

注意临界导致数组溢出

c 复制代码
int cmp(void *p1, void *p2)
{
    return (*(int *)p1 > *(int *)p2);
}

int sum(int *nums, int numsSize)
{
    int sum = 0;
    for (int i = 0; i < numsSize; i++) {
        sum += nums[i];
    }
    return sum;
}

int largestSumAfterKNegations(int* nums, int numsSize, int k) {
    // 排序
    qsort(nums, numsSize, sizeof(int), cmp);
    // 取反, 优先负数取整
    int zeroIdx = 0;
    int curIdx = 0;
    while ((k > 0) && (curIdx < numsSize) && (nums[curIdx] < 0)) {
        nums[curIdx] = 0 - nums[curIdx];
        curIdx++;
        k--;
    }
    // 判断是否未取到k次, 两两抵消后,将绝对值最小的正值取反
    if (k % 2 != 0) {
        if ((curIdx == 0) || (numsSize == 1)) {
            nums[0] = 0 - nums[0];
        }
        else if (curIdx == numsSize) {
            nums[curIdx - 1] = 0 - nums[curIdx - 1];
        }
        else
        {
            if (nums[curIdx] <= nums[curIdx - 1]) {
                nums[curIdx] = 0 - nums[curIdx];
            }
            else
            {
                nums[curIdx - 1] = 0 - nums[curIdx - 1];
            }
        }
    }
    return sum(nums, numsSize);
}
数组绝对值大小排序
c 复制代码
int cmp(void *p1, void *p2)
{
    return abs(*(int *)p1) < abs(*(int *)p2);
}

int sum(int *nums, int numsSize)
{
    int sum = 0;
    for (int i = 0; i < numsSize; i++) {
        sum += nums[i];
    }
    return sum;
}

int largestSumAfterKNegations(int* nums, int numsSize, int k) {
    // 按绝对值从大到小排序
    qsort(nums, numsSize, sizeof(int), cmp);
    // 将前k个负数取正
    for (int j = 0; j < numsSize; j++) {
        if (k == 0) {
            break;
        }
        if (nums[j] < 0) {
            nums[j] = 0 - nums[j];
            k--;
        }
    }
    // k未消耗完,将绝对值最小的元素取反,即数组最后一位
    if (k % 2 == 1) {
        nums[numsSize - 1] = 0 - nums[numsSize - 1];
    }
    // 求和
    return sum(nums, numsSize);
}

[134] 加油站

题目描述

134 加油站

解题思路

前提:

思路:

重点:

代码实现

C语言
c 复制代码

[135] 分发糖果

题目描述

135 分发糖果

解题思路

前提:

思路:

重点:

代码实现

C语言
c 复制代码

今日收获

  1. 贪心算法:艰难的应用。
相关推荐
2013092416277 小时前
1968年 Hart, Nilsson, Raphael 《最小成本路径启发式确定的形式基础》A* 算法深度研究报告
人工智能·算法
如何原谅奋力过但无声7 小时前
【力扣-Python-滑动窗口经典题】567.字符串的排列 | 424.替换后的最长重复字符 | 76.最小覆盖子串
算法·leetcode
玄冥剑尊8 小时前
贪心算法进阶
算法·贪心算法
玄冥剑尊8 小时前
贪心算法深化 I
算法·贪心算法
52Hz1189 小时前
力扣73.矩阵置零、54.螺旋矩阵、48.旋转图像
python·算法·leetcode·矩阵
BHXDML9 小时前
第一章:线性回归& 逻辑回归
算法·逻辑回归·线性回归
iAkuya9 小时前
(leetcode)力扣100 二叉搜索树种第K小的元素(中序遍历||记录子树的节点数)
算法·leetcode·职场和发展
-To be number.wan10 小时前
B 树 vs B+ 树:为什么 MySQL 用 B+ 树,而不是 B 树?
数据结构
杨间10 小时前
《排序算法全解析:从基础到优化,一文吃透八大排序!》
c语言·数据结构·排序算法
Remember_99310 小时前
【LeetCode精选算法】滑动窗口专题二
java·开发语言·数据结构·算法·leetcode