当前位置: 首页 > news >正文

西安网站设计开发人才在线网站排名工具

西安网站设计开发人才,在线网站排名工具,怎么快速仿wordpress站,阿里云个人网站备案做淘客【回溯】2023Q1-硬件产品销售方案 题目描述与示例 题目描述 某公司目前推出了 AI 开发者套件、AI 加速卡、AI 加速模块、AI 服务器、智能边缘多种硬件产品,每种产品包含若干个型号。现某合作厂商要采购金额为 amount 元的硬件产品搭建自己的 AI 基座。假设当前库…

【回溯】2023Q1-硬件产品销售方案

题目描述与示例

题目描述

某公司目前推出了 AI 开发者套件、AI 加速卡、AI 加速模块、AI 服务器、智能边缘多种硬件产品,每种产品包含若干个型号。现某合作厂商要采购金额为 amount 元的硬件产品搭建自己的 AI 基座。假设当前库存有 N 种产品,每种产品的库存量充足,给定每种产品的价格,记为 price(不存在价格相同的产品型号)。请为合作厂商列出所有可能的产品组合。

输入描述

输入包含采购金额 amount 和产品价格列表 price。第一行为 amount,第二行为 price。例如:

输出描述

输出为组合列表。例如: [[500], [200, 300], [100, 200, 200], [100, 100, 300], [100, 100, 100, 200], [100, 100, 100, 100, 100]]

备注

  1. 对于给定输入,产品组合少于 150 种。输出的组合为一个数组,数组的每个元素也是一个数组,表示一种组合方案。如果给定产品无法组合金额为 amount 元的方案,那么返回空列表。
  2. 两种组合方案,只要存在一种产品的数量不同,那么方案认为是不同的。
  3. 每种产品型号价格不相同
  4. 1 <= 产品类型数量 <= 30
  5. 100 <= 产品价格 <= 20000
  6. 100 <= 采购金额 <= 50000

示例一

输入

500
100, 200, 300, 500

输出

[[100, 100, 100, 100, 100], [100, 100, 100, 200], [100, 100, 300], [100, 200, 200], [200, 300], [500]]

示例二

输入

100
[100]

输出

[[100]]

解题思路

注意,本题和LC39. 组合总数完全一致,本质上是一道组合类型的回溯问题。

代码

# 题目:2023Q1-硬件产品销售方案
# 分值:200
# 作者:许老师-闭着眼睛学数理化
# 算法:回溯
# 代码看不懂的地方,请直接在群上提问total_sum = int(input())
nums = list(map(int, input().split(",")))# 初始化空的答案列表
ans = list()# 回溯函数
# nums:     题目给定的数字数组
# total_sum:题目给定的数字和
# ans:      答案数组
# path:     当前回溯的路径
# path_sum: 当前回溯的路径和
# startIdx: 本次递归中,nums数组中选择的开始索引
def dfs(nums, total_sum, ans, path, path_sum, startIdx):# 递归终止条件1:# 如果当前路径和path_sum >total_sum# 这条路径再往下搜寻没有意义,进行剪枝,终止当前路径继续往下搜寻if path_sum > total_sum:return# 递归终止条件2:# 如果当前路径和path_sum == total_sum,说明得到了一种组合方案# 将该种组合方案path加入ans即可,注意要使用切片或者拷贝if path_sum == total_sum:ans.append(path[:])return# 横向遍历nums中,从startIdx开始往后的所有索引for i in range(startIdx, len(nums)):# 获得i对应的数字numnum = nums[i]# 状态更新:# 1. 将num加入当前path数组中# 2. 将num加入当前path_sum路径和中path.append(num)path_sum += num# 回溯:由于num可能被反复选取,因此选择i作为下一个回溯的startIdxdfs(nums, total_sum, ans, path, path_sum, i)# 回滚:# 1. 将num从当前path数组弹出# 2. 将num从当前path_sum路径和中减去path.pop()path_sum -= num# 调用递归函数的入口,最开始path = [],path_sum = 0,startIdx = 0
dfs(nums, total_sum, ans, [], 0, 0)
print(ans)

时空复杂度

时间复杂度:O(N!)

空间复杂度:O(N)。忽略调用递归函数时编译栈所占空间,仅考虑检查数组所占用空间。

进阶思考

如果本题并不要求列出所有情况,而只是要求计算出所有方案数,应该如何用更加简便的方法解决问题?

即LC377. 组合总数IV如何完成?


华为OD算法/大厂面试高频题算法练习冲刺训练

  • 华为OD算法/大厂面试高频题算法冲刺训练目前开始常态化报名!目前已服务100+同学成功上岸!

  • 课程讲师为全网50w+粉丝编程博主@吴师兄学算法 以及小红书头部编程博主@闭着眼睛学数理化

  • 每期人数维持在20人内,保证能够最大限度地满足到每一个同学的需求,达到和1v1同样的学习效果!

  • 60+天陪伴式学习,40+直播课时,300+动画图解视频,300+LeetCode经典题,200+华为OD真题/大厂真题,还有简历修改、模拟面试、专属HR对接将为你解锁

  • 可上全网独家的欧弟OJ系统练习华子OD、大厂真题

  • 可查看链接 大厂真题汇总 & OD真题汇总(持续更新)

  • 绿色聊天软件戳 od1336了解更多

http://www.15wanjia.com/news/22311.html

相关文章:

  • 手机做车载mp3下载网站手机百度ai入口
  • 装饰logo设计图片关键词优化报价查询
  • 云南做网站找谁快速排名优化怎么样
  • 网站建设开发的流程seo优化费用
  • 背景网站建设公司百度指数是免费的吗
  • 免费b2b信息网站网站超级外链
  • 可做产品预售的网站中山做网站推广公司
  • facebook做网站淘宝大数据查询平台
  • dreamweaver网站制作教程最新推广方法
  • 普陀网站建设哪家便宜搜狗站长平台主动提交
  • 公司两个网站可以做友情链接吗sem推广什么意思
  • 佛山网站建设 奇锐科技网络营销方案设计
  • 服装网站策划设计网站应该如何进行优化
  • animate.css网站四川seo技术培训
  • 广州市专业做网站武汉seo结算
  • 网页界面设计中一般使用的分辨率上海seo外包公司
  • 快速搭建小程序站长工具seo查询5g5g
  • 网站标签spanb站网站推广mmm
  • 自己做的动态网站怎么全国教育培训机构平台
  • 嘉兴百度seoseo教学网站
  • 户外网站 整站下载seo培训班
  • 阿里巴巴b2b优化网站制作方法大全
  • 网站开发手机充值接口小红书新媒体营销案例分析
  • ecs如何搭建wordpress济南网站优化
  • ps做网站大小营销软文范例500
  • 网站搭建原则百度人工服务热线
  • 建设网站需要的材料2023年8月份新冠症状
  • 呼伦贝尔做网站的公司培训方案
  • 青岛网站建设设计怎么建设自己的网站
  • wordpress主题 投稿搜索引擎推广和优化方案