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

学习怎么做网站怎样免费建立自己网站

学习怎么做网站,怎样免费建立自己网站,开发网站建设的问卷调查,做脚本网站638. 大礼包 在 LeetCode 商店中#xff0c; 有 n 件在售的物品。每件物品都有对应的价格。然而#xff0c;也有一些大礼包#xff0c;每个大礼包以优惠的价格捆绑销售一组物品。 给你一个整数数组 price 表示物品价格#xff0c;其中 price[i] 是第 i 件物品的价格。另有…638. 大礼包 在 LeetCode 商店中 有 n 件在售的物品。每件物品都有对应的价格。然而也有一些大礼包每个大礼包以优惠的价格捆绑销售一组物品。 给你一个整数数组 price 表示物品价格其中 price[i] 是第 i 件物品的价格。另有一个整数数组 needs 表示购物清单其中 needs[i] 是需要购买第 i 件物品的数量。 还有一个数组 special 表示大礼包special[i] 的长度为 n 1 其中 special[i][j] 表示第 i 个大礼包中内含第 j 件物品的数量且 special[i][n] 也就是数组中的最后一个整数为第 i 个大礼包的价格。 返回 确切 满足购物清单所需花费的最低价格你可以充分利用大礼包的优惠活动。你不能购买超出购物清单指定数量的物品即使那样会降低整体价格。任意大礼包可无限次购买。 示例 1输入price [2,5], special [[3,0,5],[1,2,10]], needs [3,2] 输出14 解释有 A 和 B 两种物品价格分别为 ¥2 和 ¥5 。 大礼包 1 你可以以 ¥5 的价格购买 3A 和 0B 。 大礼包 2 你可以以 ¥10 的价格购买 1A 和 2B 。 需要购买 3 个 A 和 2 个 B 所以付 ¥10 购买 1A 和 2B大礼包 2以及 ¥4 购买 2A 。 示例 2输入price [2,3,4], special [[1,1,0,4],[2,2,1,9]], needs [1,2,1] 输出11 解释A B C 的价格分别为 ¥2 ¥3 ¥4 。 可以用 ¥4 购买 1A 和 1B 也可以用 ¥9 购买 2A 2B 和 1C 。 需要买 1A 2B 和 1C 所以付 ¥4 买 1A 和 1B大礼包 1以及 ¥3 购买 1B ¥4 购买 1C 。 不可以购买超出待购清单的物品尽管购买大礼包 2 更加便宜。提示 n price.lengthn needs.length1 n 60 price[i] 100 needs[i] 101 special.length 100special[i].length n 10 special[i][j] 50 解题思路 预处理special数组如果大礼包内所有的物品数量都为0或者大礼包的单价小于所有物品的总价则将其剔除出去。使用深度优先搜索每一次递归就是选择任意一份大礼包或者不购买大礼包全部按所需物品的单价购买计算购买该大礼包以后仍每种物品仍然需要的数量大小进行下一次递归如果超出购物清单指定数量的物品则不进行递归返回最小花费的组合方式。使用记忆化搜索使用map记录下所需物品清单和其花费最低价格的映射避免重复计算某种所需物品清单的最低价格。 代码 class Solution {MapListInteger, Integer map new HashMap();public int shoppingOffers(ListInteger price, ListListInteger special, ListInteger needs) {ListListInteger filter new ArrayList();for (ListInteger integerList : special) {int sum 0, c 0;for (int i 0; i integerList.size() - 1; i) {sum price.get(i) * integerList.get(i);c integerList.get(i);}if (integerList.get(integerList.size() - 1) sum c 0)filter.add(integerList);}return dfs(price, needs, filter);}public int dfs(ListInteger price, ListInteger needs, ListListInteger special) {if (map.containsKey(needs)) {return map.get(needs);}int p 0, n needs.size();for (int i 0; i needs.size(); i) {p needs.get(i) * price.get(i);}for (ListInteger spec : special) {ArrayListInteger next new ArrayList();for (int i 0; i n; i) {if (spec.get(i) needs.get(i)) {break;}next.add(needs.get(i) - spec.get(i));}if (next.size() n)p Math.min(p, spec.get(n) dfs(price, next, special));}map.put(needs, p);return p;}}
http://www.zqtcl.cn/news/461379/

相关文章:

  • 贵州企业展示型网站建设wordpress文章点不开
  • 毕业设计可以做网站吗网页版征信报告查询
  • 企业网站每年的费用钢筋网片每平米重量
  • 做网站是属火的职业吗苏州网站建设信息网络
  • 怎么自己建一个论坛网站如何做中国古城的网站
  • 做网站表格网站建设综合实训案例
  • vs2012 网站开发wordpress好看的页面跳转
  • 阿里去要企业网站建设方案书小程序开发 杭州
  • 微信公众号文档网站开发与优化课程总结
  • 网站建设网课海东营销网站建设公司
  • 仿站工具教程视频宣传片免费模板
  • 美食网站建设项目分析报告莱芜都市网人才招聘
  • js做网站福田网站设计公司
  • 郑州做网站好长春市建设工程信息网站
  • 题库网站怎么做做网站文件夹都起什么名字
  • 河南网站怎么备案东台市住房和建设局网站
  • 有什么手机做网站的asp.net网站安全
  • 怎么做查询网站后台做爰的视频网站
  • 迪虎科技网站建设国际市场那个app可以看
  • 怎么做跳转不影响原网站排名wordpress添加邮箱设置
  • 网站内容规范外贸电商怎么做
  • 郑州做网站齿轮wordpress 文章h标签美化
  • 建设银行网站怎么修改手机号码吗网站建设怎样容易
  • 网站建设风险管理计划书户外媒体网站建设免费
  • 学到什么程度可以做网站网站维护的要求包括
  • 泉州网站设计平台南阳响应式网站
  • 阿里云 企业网站选哪种推广普通话的文字内容
  • 广州市南沙建设局网站中山建网站咨询电话
  • 怎么创建网站快捷方式网络服务器搭建配置与管理 下载
  • 现在什么类型网站没有人做wordpress get_categories()