0

0

基于NumPy高效计算不同价格商品分配下的客户平均价格

霞舞

霞舞

发布时间:2025-08-31 20:06:01

|

281人浏览过

|

来源于php中文网

原创

基于numpy高效计算不同价格商品分配下的客户平均价格

本文将详细介绍如何使用NumPy解决一个常见的商品分配问题:在已知商品的不同价格和数量,以及客户的订单数量的情况下,如何高效地计算每个客户的平均购买价格。 核心在于避免创建大型中间数组,从而提高计算效率。

问题描述

假设我们有一批商品,它们以不同的价格出售,并且我们知道每种价格对应的商品数量。同时,我们还有一组客户订单,每个订单对应一个客户需要购买的商品数量。我们的目标是按照先进先出的原则,将商品分配给客户,并计算每个客户的平均购买价格。

例如,我们有以下数据:

  • 订单 (orders): [21, 6, 3] (分别对应Mark, Greg, Paul的订单量)
  • 商品数量 (quantity): [16, 14] (分别对应价格为30.5和35.5的商品数量)
  • 商品价格 (price): [30.5, 35.5]

这意味着Mark想要购买21个商品,Greg想要购买6个,Paul想要购买3个。同时,我们有16个价格为30.5的商品和14个价格为35.5的商品。

解决方案:利用 NumPy 的 repeat 和 add.reduceat

一种高效的解决方案是使用NumPy的repeat和add.reduceat函数。

魔众商城系统
魔众商城系统

魔众商城系统是一个在线B2C商城系统,支持购物车、商品多分类,可以帮您快速搭建一套企业私有化的商城系统。 魔众商城系统,简约不简单的在线商城系统。 魔众商城系统是一个全面、高效且简约的B2C电商解决方案,专为希望在线上拓展业务、提升客户体验的企业和个人设计。以下是关于魔众商城系统的详细介绍: 商品管理:系统支持轻松上传商品信息、设置价格、库存等参数,并通过精美的商品详情页

下载
  1. np.repeat: 此函数可以将价格数组按照对应的商品数量进行扩展。 例如,np.repeat(price, quantity) 会生成一个数组,其中包含16个30.5和14个35.5。
  2. np.add.reduceat: 此函数可以在指定的位置对数组进行分段求和。 我们可以利用客户的订单数量来确定分段的位置,从而计算每个客户购买的商品总价。
  3. 计算平均价格: 将每个客户的总价除以其订单数量,即可得到每个客户的平均购买价格。

以下是具体的代码实现:

import numpy as np

orders = np.array([21, 6, 3], dtype=np.int64)
quantity = np.array([16, 14], dtype=np.int64)
price = np.array([30.5, 35.5], dtype=np.double)

out = np.add.reduceat(np.repeat(price, quantity),
                      np.r_[0, np.cumsum(orders)][:-1]
                     ) / orders

print(out)
# 输出: [31.69047619 35.5        35.5       ]

代码解释:

  • np.repeat(price, quantity): 创建一个新的数组,其中每个价格重复相应的数量。
  • np.cumsum(orders): 计算订单数量的累积和。
  • np.r_[0, np.cumsum(orders)][:-1]: 创建一个索引数组,用于指定add.reduceat的分段位置。 np.r_ 用于连接数组,[0, np.cumsum(orders)] 创建一个以0开始,包含订单累积和的数组。 [:-1] 切片操作用于移除最后一个元素,因为我们只需要分段的起始位置。
  • np.add.reduceat(np.repeat(price, quantity), np.r_[0, np.cumsum(orders)][:-1]): 在指定的位置对扩展后的价格数组进行分段求和。
  • / orders: 将每个客户的总价除以其订单数量,得到平均价格。

优点

与之前提到的朴素方法相比,这种方法的主要优点在于它避免了创建大型的中间数组。 np.repeat 创建的数组的大小等于所有商品数量的总和,而朴素方法中supply数组的大小也等于所有商品数量的总和。 但是通过 add.reduceat 方法,只需要对价格进行重复,避免了构建一个完整的 "supply" 数组,从而显著提高了计算效率,尤其是在处理大量商品和订单时。

注意事项

  • 数据类型: 确保 orders 和 quantity 数组的数据类型为整数类型 (例如 np.int64),price 数组的数据类型为浮点数类型 (例如 np.double),以避免潜在的类型转换问题。
  • 订单总数与商品总数: 确保所有订单的总数量等于所有商品的总数量,否则计算结果可能不准确。
  • 浮点数精度: 在处理浮点数时,可能会遇到精度问题。 如果需要更高的精度,可以考虑使用 decimal 模块。
  • 性能: 尽管这种方法比朴素方法更有效,但在处理非常大的数据集时,仍然需要考虑性能优化。 可以尝试使用NumPy的其他高级功能,例如矢量化操作和广播机制,以进一步提高计算效率。

总结

本文介绍了一种使用NumPy高效解决商品分配问题的方法。通过利用np.repeat和np.add.reduceat函数,我们可以避免创建大型中间数组,从而显著提高计算效率。 这种方法适用于处理大量商品和订单的场景,并且可以很容易地进行扩展和修改,以适应不同的业务需求。 掌握这种方法可以帮助你更高效地处理类似的数据分析和计算问题。

相关专题

更多
数据类型有哪几种
数据类型有哪几种

数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

306

2023.10.31

php数据类型
php数据类型

本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

222

2025.10.31

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

53

2025.08.29

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

99

2025.10.23

go语言 数组和切片
go语言 数组和切片

本专题整合了go语言数组和切片的区别与含义,阅读专题下面的文章了解更多详细内容。

46

2025.09.03

C++类型转换方式
C++类型转换方式

本专题整合了C++类型转换相关内容,想了解更多相关内容,请阅读专题下面的文章。

299

2025.07.15

数据分析的方法
数据分析的方法

数据分析的方法有:对比分析法,分组分析法,预测分析法,漏斗分析法,AB测试分析法,象限分析法,公式拆解法,可行域分析法,二八分析法,假设性分析法。php中文网为大家带来了数据分析的相关知识、以及相关文章等内容。

466

2023.07.04

数据分析方法有哪几种
数据分析方法有哪几种

数据分析方法有:1、描述性统计分析;2、探索性数据分析;3、假设检验;4、回归分析;5、聚类分析。本专题为大家提供数据分析方法的相关的文章、下载、课程内容,供大家免费下载体验。

279

2023.08.07

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

19

2026.01.20

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

相关下载

更多

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
誉天教育RHCE视频教程
誉天教育RHCE视频教程

共9课时 | 1.4万人学习

尚观Linux RHCE视频教程(二)
尚观Linux RHCE视频教程(二)

共34课时 | 5.7万人学习

尚观RHCE视频教程(一)
尚观RHCE视频教程(一)

共28课时 | 4.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号