LeetCode 1251. 平均售价

题目链接:1251. 平均售价

题目描述

表:Prices

Column Name Type
product_id int
start_date date
end_date date
price int

(product_id,start_date,end_date) 是 prices 表的主键(具有唯一值的列的组合)。
prices表的每一行表示的是某个产品在一段时期内的价格。 每个产品的对应时间段是不会重叠的,这也意味着同一个产品的价格时段不会出现交叉。

表:UnitsSold

Column Name Type
product_id int
purchase_date date
units int

该表可能包含重复数据。

该表的每一行表示的是每种产品的出售日期,单位和产品 id。

编写解决方案以查找每种产品的平均售价。average_price 应该四舍五入到小数点后两位 ,返回结果表无顺序要求

结果格式如下例所示。

输入:

Prices table:

product_id start_date end_date price
1 2019-02-17 2019-02-28 5
1 2019-03-01 2019-03-22 20
2 2019-02-01 2019-02-20 15
2 2019-02-21 2019-03-31 30

UnitsSold table:

product_id purchase_date units
1 2019-02-25 100
1 2019-03-01 15
2 2019-02-10 200
2 2019-03-22 30

输出:

product_id average_price
1 6.96
2 16.96

解释:

平均售价 = 产品总价 / 销售的产品数量。

产品 1 的平均售价 = ((100 * 5)+(15 * 20) )/ 115 = 6.96

产品 2 的平均售价 = ((200 * 15)+(30 * 30) )/ 230 = 16.96

题目分析

扫一眼左连接,时间范围匹配,分组求值,保留两位。OK,开始问神奇的海螺:

替换题目中的各值:

sql 复制代码
SELECT u.product_id, units * price as totalprice, u.units
FROM UnitsSold u
         LEFT JOIN Prices p
                   ON (u.purchase_date BETWEEN p.start_date AND p.end_date) AND u.product_id = p.product_id 

效果非常好!

接下来分组、计算均价、保留两位:

sql 复制代码
SELECT p.product_id, ROUND(sum(units * price) / sum(units), 2) as average_price
FROM Prices p
         LEFT JOIN UnitsSold u
                   ON (u.purchase_date BETWEEN p.start_date AND p.end_date) AND u.product_id = p.product_id
group by p.product_id

运行!

好好好,再套一个非空,下班。

代码

sql 复制代码
SELECT p.product_id, COALESCE(ROUND(sum(units * price) / sum(units), 2), 0) as average_price
FROM Prices p
         LEFT JOIN UnitsSold u
                   ON (u.purchase_date BETWEEN p.start_date AND p.end_date) AND u.product_id = p.product_id
group by p.product_id

好,又一段人下人代码,海螺全责🐚

相关推荐
阿豪学编程7 小时前
LeetCode724.:寻找数组的中心下标
算法·leetcode
墨韵流芳8 小时前
CCF-CSP第41次认证第三题——进程通信
c++·人工智能·算法·机器学习·csp·ccf
csdn_aspnet8 小时前
C# 求n边凸多边形的对角线数量(Find number of diagonals in n sided convex polygon)
开发语言·算法·c#
禹中一只鱼9 小时前
【力扣热题100学习笔记】 - 哈希
java·学习·leetcode·哈希算法
凌波粒9 小时前
LeetCode--349.两个数组的交集(哈希表)
java·算法·leetcode·散列表
paeamecium10 小时前
【PAT甲级真题】- Student List for Course (25)
数据结构·c++·算法·list·pat考试
Book思议-10 小时前
【数据结构】栈与队列全方位对比 + C 语言完整实现
c语言·数据结构·算法··队列
SteveSenna10 小时前
项目:Trossen Arm MuJoCo
人工智能·学习·算法
NAGNIP10 小时前
一文搞懂CNN经典架构-DenseNet!
算法·面试
道法自然|~10 小时前
BugCTF黄道十二宫
算法·密码学