解锁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中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

如何去写一手好SQL

MySQL性能 最大数据量 抛开数据量和并发数,谈性能都是耍流氓。MySQL没有限制单表最大记录数,它取决于操作系统对文件大小的限制。 《阿里巴巴Java开发手册》提出单表行数超过500万行或者单表容量超过2GB,才推荐分库分表。性能由综合因素决定,抛开业务复杂度,影响程度依次是硬件配置、MySQL配置、数据表设计、索引优化。500万这个值仅供参考,并非铁律。 博主曾经操作过超过4亿行数据

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

购买磨轮平衡机时应该注意什么问题和技巧

在购买磨轮平衡机时,您应该注意以下几个关键点: 平衡精度 平衡精度是衡量平衡机性能的核心指标,直接影响到不平衡量的检测与校准的准确性,从而决定磨轮的振动和噪声水平。高精度的平衡机能显著减少振动和噪声,提高磨削加工的精度。 转速范围 宽广的转速范围意味着平衡机能够处理更多种类的磨轮,适应不同的工作条件和规格要求。 振动监测能力 振动监测能力是评估平衡机性能的重要因素。通过传感器实时监

MySQL高性能优化规范

前言:      笔者最近上班途中突然想丰富下自己的数据库优化技能。于是在查阅了多篇文章后,总结出了这篇! 数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名识意,并且最后不要超过32个字符 临时库表必须以tmp_为前缀并以日期为后缀,备份

缓存雪崩问题

缓存雪崩是缓存中大量key失效后当高并发到来时导致大量请求到数据库,瞬间耗尽数据库资源,导致数据库无法使用。 解决方案: 1、使用锁进行控制 2、对同一类型信息的key设置不同的过期时间 3、缓存预热 1. 什么是缓存雪崩 缓存雪崩是指在短时间内,大量缓存数据同时失效,导致所有请求直接涌向数据库,瞬间增加数据库的负载压力,可能导致数据库性能下降甚至崩溃。这种情况往往发生在缓存中大量 k