解锁SQL无限可能 | 如何利用SQL求解力扣难题接雨水问题?

2024-08-27 13:36

本文主要是介绍解锁SQL无限可能 | 如何利用SQL求解力扣难题接雨水问题?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1  需求描述

1 数据准备

2 问题分析

3 小结


1  需求描述

原文链接:42. 接雨水 - 力扣(LeetCode)

给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。

输入:height = [0,1,0,2,1,0,1,3,2,1,2,1]
输出:6
解释:上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图,在这种情况下,可以接 6 个单位的雨水(蓝色部分表示雨水)。 

示例 2:

输入:height = [4,2,0,3,2,5]
输出:9

提示:

  • n == height.length
  • 1 <= n <= 2 * 104
  • 0 <= height[i] <= 105

1 数据准备

with rain_data as
(select array(0,1,0,2,1,0,1,3,2,1,2,1) height
)
select * from rain_data;

 

2 问题分析

本文为力扣第42题,属于hard级别。分析该问题的关键点在于"找规律,抓特征",这也是我专栏里一直提的核心技巧,语言不重要,重要的是思维方法,是算法逻辑,其余的工作只是利用语言去翻译,这一点对SQL语言尤为重要,因为语法简单的语言在实现上一定要重思维,重逻辑。

 这道题其实就是“木桶原理”,简单的说就是一个柱子能接多少水,取决于它两边“较短的板”。另外一个前提条件就是,两边的柱子高度都要比所要装水的柱子的高度要高,否则肯定是无法装水的。因此我们只需要关注左边最高的木板和右边最高的模板中较矮的一个就够了,那么存储的水,等于两边木板的较小值减去当前高度的值。用公式表示如下:

res[i] = min(l_max[i], r_max[i]) - height[i];

 我们将上述公式翻译成SQL语言即可:

第一步:先将数组展开成行

select tmp.pos + 1 id, tmp.height  heightfrom rain_datalateral view posexplode(height) tmp as pos, height

 第二步:求当前位置处,左最大与右最大

select  id, height, max(height) over(order by id) l_max, max(height) over(order by id desc) r_max
from(select tmp.pos + 1 id, tmp.height  heightfrom rain_datalateral view posexplode(height) tmp as pos, height)t;

 第三步:利用公式标记接雨水的柱子

select id,height,least(l_max,r_max) - height     as rain_flg
from
(select id, height, max(height) over (order by id)      l_max, max(height) over (order by id desc) r_maxfrom (select tmp.pos + 1 id, tmp.height  heightfrom rain_datalateral view posexplode(height) tmp as pos, height) t) t
order by id

 第四步:求出最终结果值。完整的SQL如下:

select sum(rain_flg)
from
(select least(max(tmp.height) over (order by id), max(tmp.height) over (order by id desc)) - tmp.height rain_flgfrom rain_data rlateral view posexplode(r.height) tmp as id, height) t

3 小结

本题给出上述结果,在SQL层面已经算完成了,SQL查询主要的任务就是关注特征,找出问题的特征,利用SQL提取出来就可以了,其优化方式和代码语言有所不同,对于写代码的形式,上述属于暴力求解,需要优化其两边搜所的效率,因此就会有双指针和动态规划的求解思路。虽然,但是,但对于本文一开始而言找出”木桶原理”的特征(res[i] = min(l_max[i], r_max[i]) - height[i]),也不是一件容易得事情,需要一定问题的分析能力。

关于此类如何找规律、抓特征这一思维技巧,我把他放在我的专栏数字化建设通关指南专栏里,并把所有的规律技巧整理在如下文章中,链接如下:

SQL很简单,可你却写不好?也许这才是SQL最好的教程-CSDN博客

这篇文章我将持续更新,欢迎关注并收藏,也欢迎向我提问题,我的公众号“会飞的一十六”也开通了,里面的内容和评论区也很精彩

这篇关于解锁SQL无限可能 | 如何利用SQL求解力扣难题接雨水问题?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SQL Server 中的表进行行转列场景示例

《SQLServer中的表进行行转列场景示例》本文详细介绍了SQLServer行转列(Pivot)的三种常用写法,包括固定列名、条件聚合和动态列名,文章还提供了实际示例、动态列数处理、性能优化建议... 目录一、常见场景示例二、写法 1:PIVOT(固定列名)三、写法 2:条件聚合(CASE WHEN)四、

JAVA Calendar设置上个月时,日期不存在或错误提示问题及解决

《JAVACalendar设置上个月时,日期不存在或错误提示问题及解决》在使用Java的Calendar类设置上个月的日期时,如果遇到不存在的日期(如4月31日),默认会自动调整到下个月的相应日期(... 目录Java Calendar设置上个月时,日期不存在或错误提示java进行日期计算时如果出现不存在的

Mybatis对MySQL if 函数的不支持问题解读

《Mybatis对MySQLif函数的不支持问题解读》接手项目后,为了实现多租户功能,引入了Mybatis-plus,发现之前运行正常的SQL语句报错,原因是Mybatis不支持MySQL的if函... 目录MyBATis对mysql if 函数的不支持问题描述经过查询网上搜索资料找到原因解决方案总结Myb

Nginx错误拦截转发 error_page的问题解决

《Nginx错误拦截转发error_page的问题解决》Nginx通过配置错误页面和请求处理机制,可以在请求失败时展示自定义错误页面,提升用户体验,下面就来介绍一下Nginx错误拦截转发error_... 目录1. 准备自定义错误页面2. 配置 Nginx 错误页面基础配置示例:3. 关键配置说明4. 生效

MySQL 筛选条件放 ON后 vs 放 WHERE 后的区别解析

《MySQL筛选条件放ON后vs放WHERE后的区别解析》文章解释了在MySQL中,将筛选条件放在ON和WHERE中的区别,文章通过几个场景说明了ON和WHERE的区别,并总结了ON用于关... 今天我们来讲讲数据库筛选条件放 ON 后和放 WHERE 后的区别。ON 决定如何 "连接" 表,WHERE

mysql_mcp_server部署及应用实践案例

《mysql_mcp_server部署及应用实践案例》文章介绍了在CentOS7.5环境下部署MySQL_mcp_server的步骤,包括服务安装、配置和启动,还提供了一个基于Dify工作流的应用案例... 目录mysql_mcp_server部署及应用案例1. 服务安装1.1. 下载源码1.2. 创建独立

Mysql中RelayLog中继日志的使用

《Mysql中RelayLog中继日志的使用》MySQLRelayLog中继日志是主从复制架构中的核心组件,负责将从主库获取的Binlog事件暂存并应用到从库,本文就来详细的介绍一下RelayLog中... 目录一、什么是 Relay Log(中继日志)二、Relay Log 的工作流程三、Relay Lo

MySQL日志UndoLog的作用

《MySQL日志UndoLog的作用》UndoLog是InnoDB用于事务回滚和MVCC的重要机制,本文主要介绍了MySQL日志UndoLog的作用,文中介绍的非常详细,对大家的学习或者工作具有一定的... 目录一、Undo Log 的作用二、Undo Log 的分类三、Undo Log 的存储四、Undo

MySQL游标和触发器的操作流程

《MySQL游标和触发器的操作流程》本文介绍了MySQL中的游标和触发器的使用方法,游标可以对查询结果集进行逐行处理,而触发器则可以在数据表发生更改时自动执行预定义的操作,感兴趣的朋友跟随小编一起看看... 目录游标游标的操作流程1. 定义游标2.打开游标3.利用游标检索数据4.关闭游标例题触发器触发器的基

MySQL查看表的历史SQL的几种实现方法

《MySQL查看表的历史SQL的几种实现方法》:本文主要介绍多种查看MySQL表历史SQL的方法,包括通用查询日志、慢查询日志、performance_schema、binlog、第三方工具等,并... 目录mysql 查看某张表的历史SQL1.查看MySQL通用查询日志(需提前开启)2.查看慢查询日志3.