解锁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

相关文章

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

IDEA和GIT关于文件中LF和CRLF问题及解决

《IDEA和GIT关于文件中LF和CRLF问题及解决》文章总结:因IDEA默认使用CRLF换行符导致Shell脚本在Linux运行报错,需在编辑器和Git中统一为LF,通过调整Git的core.aut... 目录问题描述问题思考解决过程总结问题描述项目软件安装shell脚本上git仓库管理,但拉取后,上l

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

mysql8.0.43使用InnoDB Cluster配置主从复制

《mysql8.0.43使用InnoDBCluster配置主从复制》本文主要介绍了mysql8.0.43使用InnoDBCluster配置主从复制,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录1、配置Hosts解析(所有服务器都要执行)2、安装mysql shell(所有服务器都要执行)3、

通过React实现页面的无限滚动效果

《通过React实现页面的无限滚动效果》今天我们来聊聊无限滚动这个现代Web开发中不可或缺的技术,无论你是刷微博、逛知乎还是看脚本,无限滚动都已经渗透到我们日常的浏览体验中,那么,如何优雅地实现它呢?... 目录1. 早期的解决方案2. 交叉观察者:IntersectionObserver2.1 Inter

k8s中实现mysql主备过程详解

《k8s中实现mysql主备过程详解》文章讲解了在K8s中使用StatefulSet部署MySQL主备架构,包含NFS安装、storageClass配置、MySQL部署及同步检查步骤,确保主备数据一致... 目录一、k8s中实现mysql主备1.1 环境信息1.2 部署nfs-provisioner1.2.

idea npm install很慢问题及解决(nodejs)

《ideanpminstall很慢问题及解决(nodejs)》npm安装速度慢可通过配置国内镜像源(如淘宝)、清理缓存及切换工具解决,建议设置全局镜像(npmconfigsetregistryht... 目录idea npm install很慢(nodejs)配置国内镜像源清理缓存总结idea npm in

pycharm跑python项目易出错的问题总结

《pycharm跑python项目易出错的问题总结》:本文主要介绍pycharm跑python项目易出错问题的相关资料,当你在PyCharm中运行Python程序时遇到报错,可以按照以下步骤进行排... 1. 一定不要在pycharm终端里面创建环境安装别人的项目子模块等,有可能出现的问题就是你不报错都安装

MySQL中VARCHAR和TEXT的区别小结

《MySQL中VARCHAR和TEXT的区别小结》MySQL中VARCHAR和TEXT用于存储字符串,VARCHAR可变长度存储在行内,适合短文本;TEXT存储在溢出页,适合大文本,下面就来具体的了解... 目录一、VARCHAR 和 TEXT 基本介绍1. VARCHAR2. TEXT二、VARCHAR

idea突然报错Malformed \uxxxx encoding问题及解决

《idea突然报错Malformeduxxxxencoding问题及解决》Maven项目在切换Git分支时报错,提示project元素为描述符根元素,解决方法:删除Maven仓库中的resolv... 目www.chinasem.cn录问题解决方式总结问题idea 上的 maven China编程项目突然报错,是