【代码随想录】【算法训练营】【第37天】 [56]合并区间 [738]单调递增的数字 [968]监控二叉树

本文主要是介绍【代码随想录】【算法训练营】【第37天】 [56]合并区间 [738]单调递增的数字 [968]监控二叉树,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

思路及算法思维,指路 代码随想录。
题目来自 LeetCode。

day 37,周四,坚持~

题目详情

[56] 合并区间

题目描述

56 合并区间
56 合并区间

解题思路

前提:判断区间是否重合。
思路:按照左边界从小到大排序,遍历区间,判断区间是否有重叠,重叠区间合并。
重点:判断区间重合。

代码实现

C语言
贪心思维

按照左边界从小到大排序,遍历区间,判断区间是否有重叠,重叠区间合并。

/*** Return an array of arrays of size *returnSize.* The sizes of the arrays are returned as *returnColumnSizes array.* Note: Both returned array and *columnSizes array must be malloced, assume caller calls free().*/int cmp(const void *p1, const void *p2)
{int *pp1 = *(int **)p1;int *pp2 = *(int **)p2;// 按照左边界从小到大排序,左边界相同按右边界从小到大排序return (pp1[0] == pp2[0]) ? (pp1[1] - pp2[1]) : (pp1[0] - pp2[0]);
}int** merge(int** intervals, int intervalsSize, int* intervalsColSize, int* returnSize, int** returnColumnSizes) {// 按照左边界从小到大排序,左边界相同按右边界从小到大排序qsort(intervals, intervalsSize, sizeof(int *), cmp);for (int k = 0; k < intervalsSize; k++) {}//输出初始化int **ans = (int **)malloc(sizeof(int *) * intervalsSize);int ansSize = 0;// 遍历区间,重叠区间合并int curStart = intervals[0][0];int curEnd = intervals[0][1];for (int i = 1; i < intervalsSize; i++) {// 判断区间是否有重叠if (intervals[i][0] <= curEnd) {if (curEnd < intervals[i][1]) {curEnd = intervals[i][1];}} else {// 不重叠部分,保存上一段区间ans[ansSize] = (int *)malloc(sizeof(int) * (*intervalsColSize));ans[ansSize][0] = curStart;ans[ansSize][1] = curEnd;ansSize++;// 保存当前区间起始位置curStart = intervals[i][0];curEnd = intervals[i][1];}}// 保存当前区间ans[ansSize] = (int *)malloc(sizeof(int) * (*intervalsColSize));ans[ansSize][0] = curStart;ans[ansSize][1] = curEnd;ansSize++;// 输出*returnSize = ansSize;*returnColumnSizes = (int *)malloc(sizeof(int) * ansSize);for (int j = 0; j < ansSize; j++) {(*returnColumnSizes)[j] = *intervalsColSize;}return ans;
}

[738] 单调递增的数字

题目描述

738 单调递增的数字
738 单调递增的数字

解题思路

前提:求数字呈单调递增。
思路:从后往前遍历字符数组,判断单调递增, 标识赋9的位置,将标记位及其之后均赋字符9,最后字符数组转数值输出。
重点:贪心思维。

代码实现

C语言
贪心思维

从后往前遍历字符数组,判断单调递增, 标识赋9的位置,将标记位及其之后均赋字符9,字符数组转数值输出。

#define MAX_NUM_LEN  (11)int monotoneIncreasingDigits(int n) {char numArray[MAX_NUM_LEN];int arrLen = 0;// 数字转换字符arrLen = sprintf(numArray, "%d", n);// 从后往前遍历数组int flag = arrLen;for (int i = arrLen - 1; i > 0; i--) {// 判断单调递增if (numArray[i - 1] > numArray[i]) {// 标识赋9的位置,其后所有均赋9flag = i;numArray[i - 1] -= 1;}}// 将标记位及其之后均赋字符9for (int j = flag; j < arrLen; j++) {numArray[j] = '9';}// 字符数组转数值return atoi(numArray);
}

[968] 监控二叉树

题目描述

968 监控二叉树
968 监控二叉树

解题思路

前提:二叉树遍历
思路:局部最优:让叶子节点的父节点安摄像头,所用摄像头最少;整体最优:全部摄像头数量所用最少。
重点:二叉树遍历方式;如果标识结点是否需要安装摄像头。

代码实现

C语言
贪心算法

局部最优:让叶子节点的父节点安摄像头,所用摄像头最少;整体最优:全部摄像头数量所用最少。
从叶子结点向根节点遍历,使用后序(左右中)遍历二叉树结点。
标识结点的3种状态:0 - 无覆盖(初始状态), 1 - 有覆盖, 2 - 安装摄像头

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     struct TreeNode *left;*     struct TreeNode *right;* };*/int count = 0;// 返回值标识当前root结点 0 - 无覆盖, 1 - 有覆盖, 2 - 有摄像头
int travsel(struct TreeNode *root)
{// 空节点返回有覆盖状态1if (root == NULL) {return 1;}// 后序遍历,左右中int left = travsel(root->left);int right = travsel(root->right);// 判断当前根节点状态int mid = 0;if ((left == 1) && (right == 1)) {// 左右子节点均有覆盖时,该节点无覆盖mid = 0;} else if ((left == 0) || (right == 0)) {// 左右结点至少有一个无覆盖时,该节点需要安装摄像头mid = 2;count++;}else {// 其他情况:左右结点至少有一个有摄像头时,该结点有覆盖mid = 1;}return mid;
}int minCameraCover(struct TreeNode* root) {// 全局变量初始化count = 0;// 后序遍历二叉树,判断当前结点是否无覆盖,需要安装摄像头// 根节点if (travsel(root) == 0) {count++;}return count;
}

今日收获

  1. 贪心算法:若有若无的贪心思维,不是很容易想到的解法。

这篇关于【代码随想录】【算法训练营】【第37天】 [56]合并区间 [738]单调递增的数字 [968]监控二叉树的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1058075

相关文章

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一

在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码

《在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码》在MyBatis的XML映射文件中,trim元素用于动态添加SQL语句的一部分,处理前缀、后缀及多余的逗号或连接符,示... 在MyBATis的XML映射文件中,<trim>元素用于动态地添加SQL语句的一部分,例如SET或W

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

基于C#实现PDF文件合并工具

《基于C#实现PDF文件合并工具》这篇文章主要为大家详细介绍了如何基于C#实现一个简单的PDF文件合并工具,文中的示例代码简洁易懂,有需要的小伙伴可以跟随小编一起学习一下... 界面主要用于发票PDF文件的合并。经常出差要报销的很有用。代码using System;using System.Col

使用zabbix进行监控网络设备流量

《使用zabbix进行监控网络设备流量》这篇文章主要为大家详细介绍了如何使用zabbix进行监控网络设备流量,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录安装zabbix配置ENSP环境配置zabbix实行监控交换机测试一台liunx服务器,这里使用的为Ubuntu22.04(

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

Python视频剪辑合并操作的实现示例

《Python视频剪辑合并操作的实现示例》很多人在创作视频时都需要进行剪辑,本文主要介绍了Python视频剪辑合并操作的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录介绍安装FFmpegWindowsMACOS安装MoviePy剪切视频合并视频转换视频结论介绍

python多进程实现数据共享的示例代码

《python多进程实现数据共享的示例代码》本文介绍了Python中多进程实现数据共享的方法,包括使用multiprocessing模块和manager模块这两种方法,具有一定的参考价值,感兴趣的可以... 目录背景进程、进程创建进程间通信 进程间共享数据共享list实践背景 安卓ui自动化框架,使用的是

SpringBoot生成和操作PDF的代码详解

《SpringBoot生成和操作PDF的代码详解》本文主要介绍了在SpringBoot项目下,通过代码和操作步骤,详细的介绍了如何操作PDF,希望可以帮助到准备通过JAVA操作PDF的你,项目框架用的... 目录本文简介PDF文件简介代码实现PDF操作基于PDF模板生成,并下载完全基于代码生成,并保存合并P

springboot健康检查监控全过程

《springboot健康检查监控全过程》文章介绍了SpringBoot如何使用Actuator和Micrometer进行健康检查和监控,通过配置和自定义健康指示器,开发者可以实时监控应用组件的状态,... 目录1. 引言重要性2. 配置Spring Boot ActuatorSpring Boot Act