C语言 | Leetcode C语言题解之第218题天际线问题

题目:

题解:

struct pair {int first, second;
};struct Heap {struct pair* heap;int heapSize;bool (*cmp)(struct pair*, struct pair*);
};void init(struct Heap* obj, int n, bool (*cmp)(struct pair*, struct pair*)) {obj->heap = malloc(sizeof(struct pair) * (n + 1));obj->heapSize = 0;obj->cmp = cmp;
}bool cmp1(struct pair* a, struct pair* b) {return a->second < b->second;
}void swap(struct pair* a, struct pair* b) {struct pair tmp = *a;*a = *b, *b = tmp;
}void push(struct Heap* obj, int x, int y) {int p = ++(obj->heapSize), q = p >> 1;obj->heap[p] = (struct pair){x, y};while (q) {if (!obj->cmp(&(obj->heap[q]), &(obj->heap[p]))) {break;}swap(&(obj->heap[q]), &(obj->heap[p]));p = q, q = p >> 1;}
}void pop(struct Heap* obj) {swap(&(obj->heap[1]), &(obj->heap[(obj->heapSize)--]));int p = 1, q = p << 1;while (q <= obj->heapSize) {if (q + 1 <= obj->heapSize) {if (obj->cmp(&(obj->heap[q]), &(obj->heap[q + 1]))) {q++;}}if (!obj->cmp(&(obj->heap[p]), &(obj->heap[q]))) {break;}swap(&(obj->heap[q]), &(obj->heap[p]));p = q, q = p << 1;}
}struct pair top(struct Heap* obj) {return obj->heap[1];
}bool empty(struct Heap* obj) {return obj->heapSize == 0;
}int cmp(int* a, int* b) {return *a - *b;
}int** getSkyline(int** buildings, int buildingsSize, int* buildingsColSize, int* returnSize, int** returnColumnSizes) {int n = buildingsSize;struct Heap* heap = malloc(sizeof(struct Heap));init(heap, n << 1, cmp1);int boundaries[n << 1];for (int i = 0; i < n; i++) {boundaries[i << 1] = buildings[i][0];boundaries[i << 1 | 1] = buildings[i][1];}qsort(boundaries, n << 1, sizeof(int), cmp);int** ret = malloc(sizeof(int*) * (n << 1));*returnColumnSizes = malloc(sizeof(int) * (n << 1));*returnSize = 0;int idx = 0;for (int i = 0; i < (n << 1); i++) {int boundary = boundaries[i];while (idx < n && buildings[idx][0] <= boundary) {push(heap, buildings[idx][1], buildings[idx][2]);idx++;}while (!empty(heap) && top(heap).first <= boundary) {pop(heap);}int maxn = empty(heap) ? 0 : top(heap).second;if ((*returnSize) == 0 || maxn != ret[(*returnSize) - 1][1]) {int* tmp = malloc(sizeof(int) * 2);tmp[0] = boundary, tmp[1] = maxn;(*returnColumnSizes)[*returnSize] = 2;ret[(*returnSize)++] = tmp;}}return ret;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/41229.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

调制信号识别系列 (一):基准模型

调制信号识别系列 (一)&#xff1a;基准模型 说明&#xff1a;本文包含对CNN和CNNLSTM基准模型的复现&#xff0c;模型架构参考下述两篇文章 文章目录 调制信号识别系列 (一)&#xff1a;基准模型一、论文1、DL-PR: Generalized automatic modulation classification method b…

软件架构之操作系统

第 2 章操作系统 本章主要介绍操作系统的基本概念及其形成、发展历史和主要类型&#xff0c;并指出操作系统的5 大管理功能。掌握操作系统原理的关键在于深入理解“一个观点、两条线索”。一个观点是以资源管理的观点来定义操作系统&#xff1b;两条线索是指操作系统如何管理计…

【计算机毕业设计】020基于weixin小程序订餐系统

&#x1f64a;作者简介&#xff1a;拥有多年开发工作经验&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的项目或者毕业设计。 代码可以私聊博主获取。&#x1f339;赠送计算机毕业设计600个选题excel文件&#xff0c;帮助大学选题。赠送开题报告模板&#xff…

C语言获取当前时间

一共有两段代码&#xff0c;一个是获取当前时间&#xff0c;一个是获取到现在的总毫秒数 求关注&#x1f604; 互粉必回 获取当前时间 #include <stdio.h> #include <time.h> int main() { time_t rawtime; struct tm * timeinfo; char buffer[20]; // 获取当前…

Linux内核编译与调试menuos-linux-3.18.6-在ubuntu20.04环境

1 具体操作 下载 linux-3.18.6内核 wget https://www.kernel.org/pub/linux/kernel/v3.x/linux-3.18.6.tar.xz解压进入linux-3.18.6文件夹 tar -xvf linux-3.18.6.tar.xz cd linux-3.18.6/编译 #make x86_64_defconfig # 为x86_64生成配置 #make alldefconfig make i3…

每天一个数据分析题(四百零十)- 主成分

实际应用中&#xff0c;关于主成分数量K的取值&#xff0c;下列说法错误的是&#xff08; &#xff09; A. 可以基于碎石图进行判断 B. 特征根从大到小排序&#xff0c;通常要求前 K 个特征根都大于 1 C. 通常要求 K 个主成分的累积方差比超过 80% D. 各个主成分之间的方向…

什么是区块链的“智能合约”

区块链的“智能合约”是一种存储在区块链上的计算机协议&#xff0c;它能够自动执行合约条款&#xff0c;并在满足预设条件时自动执行相关操作。智能合约通过编程语言&#xff08;如Solidity&#xff09;编写&#xff0c;可以在去中心化的环境中运行&#xff0c;无需人工干预。…

spdlog一个非常好用的C++日志库(七): 源码分析之异常类spdlog_ex

目录 1.自定义异常类spdlog_ex 1.1.通用异常 1.2.系统调用异常 1.3.what()函数 2.异常的使用 2.1.抛出异常 2.2.控制异常使用 1.自定义异常类spdlog_ex 标准库异常类&#xff08;std::exception&#xff09;系列&#xff0c;能满足大多数使用异常的场景&#xff0c;但对…

100359.统计X和Y频数相等的子矩阵数量

1.题目描述 给你一个二维字符矩阵 grid&#xff0c;其中 grid[i][j] 可能是 X、Y 或 .&#xff0c;返回满足以下条件的子矩阵数量&#xff1a; 包含 grid[0][0]X 和 Y 的频数相等。至少包含一个 X。 示例 1&#xff1a; 输入&#xff1a; grid [["X","Y",…

Avalonia中的样式

文章目录 前言样式定义代码切换样式样式主题前言 Avalonia的样式是Styles,与WPF类似。用于在控件之间共享属性设置用于在控件之间共享属性设置,样式由 Selector和属性组成。 样式定义 下面定义一个最简单的样式 <Window.Styles><Style Selector="TextBlock…

双 Token 无感刷新机制实现

✅作者简介&#xff1a;热爱Java后端开发的一名学习者&#xff0c;大家可以跟我一起讨论各种问题喔。 &#x1f34e;个人主页&#xff1a;Hhzzy99 &#x1f34a;个人信条&#xff1a;坚持就是胜利&#xff01; &#x1f49e;当前专栏&#xff1a;项目实践 &#x1f96d;本文内容…

微信小程序性能与体验优化

1. 合理的设置可点击元素的响应区域大小&#xff1b; 比较常见的是页面的点击按钮太小&#xff0c;用户点击不到按钮&#xff0c;这样用户体验很不好。 2. 避免渲染页面耗时过长&#xff1b; 当页面渲染时间过长的话&#xff0c;会让用户感觉非常卡顿&#xff0c;当出现这种…

密室逃脱——收集版修改测试

一、原版修改 1、导入资源 Unity Learn | 3D Beginner: Complete Project | URP 2、设置Scene 删除SampleScene&#xff0c;打开UnityTechnologies-3DBeginnerComplete下的MainScene 3、降低音量 (1) 打开Hierarchy面板上的Audio降低音量 (2) 打开Prefabs文件夹&#xf…

lnmp php7 安装ssh2扩展

安装ssh2扩展前必须安装libssh2包 下载地址: wget http://www.libssh2.org/download/libssh2-1.11.0.tar.gzwget http://pecl.php.net/get/ssh2-1.4.tgz &#xff08;这里要换成最新的版本&#xff09; 先安装 libssh2 再安装 SSH2: tar -zxvf libssh2-1.11.0.tar.gzcd libss…

若依框架(RuoYi)中实现部门及子部门用户查询的SQL逻辑解析

前言 在基于若依框架&#xff08;RuoYi&#xff09;的项目开发中&#xff0c;经常会遇到需要根据部门ID查询其下属所有用户的需求&#xff0c;包括直接隶属于该部门的用户以及属于其子部门的所有用户。这一需求在组织架构管理、权限分配等场景中尤为常见。本文将深入解析一段典…

【深入理解计算机系统——2信息的表示和处理】

计算机的本质就是二进制&#xff0c;0/1&#xff0c;称之为bit&#xff08;位&#xff09;&#xff0c;一个位没有什么意义&#xff0c;当同时拥有多个位&#xff0c;并且加上某种解释&#xff0c;就可以表示任何有限集合的元素。&#xff08;为什么是有限&#xff1f;因为用bi…

【日志信息管理】管理日志信息的类

日志用于记录程序的执行记录包括程序的出错记录&#xff0c;程序致命退出原因&#xff0c;程序的正常执行记录。这样我们就可以很快的察觉程序的错误原因、执行状况等等&#xff0c;因此管理日志信息是非常重要的。 日志一般由以下部分组合&#xff1a; 日志时间、日志等级、…

Java 基础--File - IO流(2)

I/O流 定义 数据从硬盘流向内存为输入流&#xff0c;数据从内存流向硬盘为输出流。输入也叫读取数据&#xff0c;输出也叫写出数据。 IO分类 1.按照数据的流向分为&#xff1a;输入流和输出流 ①输入流&#xff1a;把数据从其他设备上读取到内存中的流 ②输出流&#xff1…

Qt 基础组件速学 事件过滤器

学习目标&#xff1a;理解事件过滤器 前置环境 运行环境:qt creator 4.12 学习内容和效果演示&#xff1a; Qt 提供了事件过滤器的机制,允许我们在事件到达目标对象之前对事件进行拦截和处理。这在以下情况下非常有用: 全局事件处理: 我们可以在应用程序级别安装一个事件过…

工控人最爱的PLC触摸屏一体机,有多香

PLC触摸屏一体机是什么 PLC触摸屏一体机&#xff0c;听起来可能有点技术化&#xff0c;但简单来说&#xff0c;它就是一个集成了可编程逻辑控制器&#xff08;PLC&#xff09;和触摸屏的智能设备。这种设备不仅能够执行自动化控制任务&#xff0c;还能实时显示和操作设备状态&a…