【代码随想录】【算法训练营】【第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进行监控进程的黑科技

《一文解密Python进行监控进程的黑科技》在计算机系统管理和应用性能优化中,监控进程的CPU、内存和IO使用率是非常重要的任务,下面我们就来讲讲如何Python写一个简单使用的监控进程的工具吧... 目录准备工作监控CPU使用率监控内存使用率监控IO使用率小工具代码整合在计算机系统管理和应用性能优化中,监

Python实现MQTT通信的示例代码

《Python实现MQTT通信的示例代码》本文主要介绍了Python实现MQTT通信的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 安装paho-mqtt库‌2. 搭建MQTT代理服务器(Broker)‌‌3. pytho

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

prometheus如何使用pushgateway监控网路丢包

《prometheus如何使用pushgateway监控网路丢包》:本文主要介绍prometheus如何使用pushgateway监控网路丢包问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录监控网路丢包脚本数据图表总结监控网路丢包脚本[root@gtcq-gt-monitor-prome

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

如何在Ubuntu 24.04上部署Zabbix 7.0对服务器进行监控

《如何在Ubuntu24.04上部署Zabbix7.0对服务器进行监控》在Ubuntu24.04上部署Zabbix7.0监控阿里云ECS服务器,需配置MariaDB数据库、开放10050/1005... 目录软硬件信息部署步骤步骤 1:安装并配置mariadb步骤 2:安装Zabbix 7.0 Server

Python使用python-can实现合并BLF文件

《Python使用python-can实现合并BLF文件》python-can库是Python生态中专注于CAN总线通信与数据处理的强大工具,本文将使用python-can为BLF文件合并提供高效灵活... 目录一、python-can 库:CAN 数据处理的利器二、BLF 文件合并核心代码解析1. 基础合

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示