LC 638. Shopping Offers
In LeetCode Store, there are some kinds of items to sell. Each item has a price.
However, there are some special offers, and a special offer consists of one or more different kinds of items with a sale price.
You are given the each item's price, a set of special offers, and the number we need to buy for each item. The job is to output the lowest price you have to pay for exactly certain items as given, where you could make optimal use of the special offers.
Each special offer is represented in the form of an array, the last number represents the price you need to pay for this special offer, other numbers represents how many specific items you could get if you buy this offer.
You could use any of special offers as many times as you want.
Example 1:
Input: [2,5], [[3,0,5],[1,2,10]], [3,2]
Output: 14
Explanation:
There are two kinds of items, A and B. Their prices are $2 and $5 respectively.
In special offer 1, you can pay $5 for 3A and 0B
In special offer 2, you can pay $10 for 1A and 2B.
You need to buy 3A and 2B, so you may pay $10 for 1A and 2B (special offer #2), and $4 for 2A.
Example 2:
Input: [2,3,4], [[1,1,0,4],[2,2,1,9]], [1,2,1]
Output: 11
Explanation:
The price of A is $2, and $3 for B, $4 for C.
You may pay $4 for 1A and 1B, and $9 for 2A ,2B and 1C.
You need to buy 1A ,2B and 1C, so you may pay $4 for 1A and 1B (special offer #1), and $3 for 1B, $4 for 1C.
You cannot add more items, though only $9 for 2A ,2B and 1C.
Note:
- There are at most 6 kinds of items, 100 special offers.
- For each item, you need to buy at most 6 of them.
- You are not allowed to buy more items than you want, even if that would lower the overall price.
Runtime: 53 ms, faster than 12.62% of Java online submissions for Shopping Offers.
自己的揭发,但是时间有点低,纯粹暴力搜索。
先把总的不加优惠券的价格算出来,然后每次遍历优惠券,直到不能再用优惠券。每次用优惠券都是DFS,且保存当前优化的结果,这又是BFS。
class Solution {
public int shoppingOffers(List<Integer> price, List<List<Integer>> special, List<Integer> needs) {
int maxval = 0;
int cnt = 0;
for(int x : needs){
maxval += x * price.get(cnt);
cnt++;
}
return helper(price, special, needs, maxval);
}
int helper(List<Integer> price, List<List<Integer>> special, List<Integer> needs, int maxval){
int tmpmax = maxval;
for(int i=0; i<special.size(); i++){
List<Integer> newneeds = new ArrayList<>();
for(int n : needs) newneeds.add(n);
boolean canuse = true;
int delta = maxval;
for(int j=0; j<special.get(i).size()-1; j++){
if(newneeds.get(j) < special.get(i).get(j)){
canuse = false;
break;
}else {
delta -= special.get(i).get(j) * price.get(j);
newneeds.set(j, newneeds.get(j) - special.get(i).get(j));
}
}
if(canuse) {
delta += special.get(i).get(special.get(i).size()-1);
tmpmax = Math.min(tmpmax, helper(price, special, newneeds, delta));
}
}
return tmpmax;
}
}
一个更好的解法
Runtime: 12 ms, faster than 90.29% of Java online submissions for Shopping Offers.
优化解法,
1. 遍历的时候,可以记录当前index,也就是说不需要每次从头遍历,因为只是使用优惠券顺序的关系而已。
2. 我之前会用backtracking偷懒只用一个needs,用到了set,这十分费时。直接开一个新的newneeds,每次用add,效果十分好。
class Solution {
public int shoppingOffers(List<Integer> price, List<List<Integer>> special, List<Integer> needs) {
int maxval = 0;
int cnt = 0;
for(int x : needs){
maxval += x * price.get(cnt);
cnt++;
}
return helper(price, special, needs, maxval,0);
}
int helper(List<Integer> price, List<List<Integer>> special, List<Integer> needs, int maxval, int spindex){
int tmpmax = maxval;
// StringBuilder sb = new StringBuilder();
// for(int i=0; i<needs.size(); i++){
// sb.append(needs.get(i));
// sb.append("+");
// }
// if(mp.containsKey(sb.toString())) return mp.get(sb.toString());
for(int i=spindex; i<special.size(); i++){
//List<Integer> newneeds = new ArrayList<>();
//for(int n : needs) newneeds.add(n);
//if(special.get(i).get(special.get(i).size()-1) <= maxval - tmpmax) continue;
//boolean canuse = true;
int delta = maxval;
List<Integer> newneeds = new ArrayList<>();
for(int j=0; j<special.get(i).size()-1; j++){
//if(newneeds.get(j) < special.get(i).get(j)){
if(needs.get(j) < special.get(i).get(j)){
//canuse = false;
newneeds = null;
break;
//needs.set(j, needs.get(j) - special.get(i).get(j));
}else {
delta -= special.get(i).get(j) * price.get(j);
newneeds.add(needs.get(j) - special.get(i).get(j));
//newneeds.set(j, newneeds.get(j) - special.get(i).get(j));
//needs.set(j, needs.get(j) - special.get(i).get(j));
}
}
if(newneeds != null) {
delta += special.get(i).get(special.get(i).size()-1);
tmpmax = Math.min(tmpmax, helper(price, special, newneeds, delta, i));
}
// for(int k=0; k<special.get(i).size()-1; k++){
// needs.set(k, needs.get(k) + special.get(i).get(k));
// }
}
// sb = new StringBuilder();
// for(int k=0; k<needs.size(); k++){
// sb.append(k);
// sb.append("+");
// }
// mp.put(sb.toString(), maxval);
return tmpmax;
}
}
LC 638. Shopping Offers的更多相关文章
- LeetCode 638 Shopping Offers
题目链接: LeetCode 638 Shopping Offers 题解 dynamic programing 需要用到进制转换来表示状态,或者可以直接用一个vector来保存状态. 代码 1.未优 ...
- Week 9 - 638.Shopping Offers - Medium
638.Shopping Offers - Medium In LeetCode Store, there are some kinds of items to sell. Each item has ...
- 638. Shopping Offers
In LeetCode Store, there are some kinds of items to sell. Each item has a price. However, there are ...
- 【leetcode】638. Shopping Offers
题目如下: In LeetCode Store, there are some kinds of items to sell. Each item has a price. However, ther ...
- 【LeetCode】638. Shopping Offers 解题报告(Python & C++)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 DFS 回溯法 日期 题目地址:https://le ...
- Leetcode之深度优先搜索&回溯专题-638. 大礼包(Shopping Offers)
Leetcode之深度优先搜索&回溯专题-638. 大礼包(Shopping Offers) 深度优先搜索的解题详细介绍,点击 在LeetCode商店中, 有许多在售的物品. 然而,也有一些大 ...
- 洛谷P2732 商店购物 Shopping Offers
P2732 商店购物 Shopping Offers 23通过 41提交 题目提供者该用户不存在 标签USACO 难度提高+/省选- 提交 讨论 题解 最新讨论 暂时没有讨论 题目背景 在商店中, ...
- poj 1170 Shopping Offers
Shopping Offers Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 4696 Accepted: 1967 D ...
- USACO 3.3 Shopping Offers
Shopping OffersIOI'95 In a certain shop, each kind of product has an integer price. For example, the ...
随机推荐
- MySQL跨表更新SQL
1 sql范式 把s表中的city_name的值设置为city表中的name,关联条件是city_code 和 code update student s, city c set s.city_na ...
- git本地仓库删除后从远程仓库更新代码
1.$ ssh-agent bash 2.$ ssh-add ~/.ssh/id_rsa_hyp 添加ssh密匙 3.$ git fetch git@github.com:xxx.git master ...
- python 之math模块
一.math 简介 import math # 导入模块 ret = dir(math) # 查看所有函数名列表 print(ret) # ['__doc__', '__loader__', '__n ...
- tsung压力测试环境部署详细步骤(内附安装包)
操作系统: Redhat 6.3.Redhat6.5 .centos7.4(这些版本已验证过) tsung版本: tsung-1.6.0 下载地址: 链接: https://pan.baidu.com ...
- mongodb命令---创建数据库,插入文档,更新文档记录
创建数据库----基本就是使用隐式创建 例如 use 你定义的数据库名, use dingsmongo 如果你使用的是studio 3T软件,那直接选中右侧的地址栏点击右键选择Add Databas ...
- P4145——线段树点修改&&模板题
题目 链接 题意:对一个数列进行以下两种操作: 给$[l,r]$中的每个数开平方(下取整) 询问$[l,r]$中各个数的和 解决方法 显然,区间开平方不满足区间可加性,所以对区间中每个数开平方不能通过 ...
- mysql 主从复制不一致,不停库不锁表恢复主从同步
注意: 进行此操作时,确认在之前已经开启了MySQL的bin-log日志,如果没有则无法实现 为了安全考虑,我们授权一个用户进行数据备份: [root@7con ] mysql -uroot -p m ...
- 类数组对象HTMLCollenction
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8&qu ...
- Codeforces Round #346 (Div. 2) E题 并查集找环
E. New Reform Berland has n cities connected by m bidirectional roads. No road connects a city to it ...
- Luogu P4398 [JSOI2008]Blue Mary的战役地图 矩阵哈希
其实可以二分矩阵边长但是我太懒了$qwq$. 把每个子矩阵扔到$map$里,然后就没了 #include<cstdio> #include<map> #include<i ...