算法描述:预算N,酒店数M,数组存储每个酒店单晚的价格,求最少能住的天数
示例:预算1000,酒店3,分别是300,600,2的价格,最少能住52天
暴力解决:
function toTheMin(n,m,arr,res) {
var valueList = arr,
budget = n,
num = m,
flag = 0;
for(var i = 0, l = valueList.length; i < l; i++) {
if(valueList[i] <= budget && (valueList[i + 1] > budget) || (i == l - 1)) {
flag = 1;
var min = Math.floor(budget / valueList[i]);
budget = budget - min * valueList[i];
if(budget < valueList[0]) {
var res = min + res;
return res;
}else {
return toTheMin(budget, i+1, valueList.slice(0,i), min+res);
}
}
}
if(flag == 0) {
return 0;
}
}
var arr = [300, 600, 200];
var list = arr.sort(function(a, b) {
return a - b;
});
var num = list.length;
toTheMin(1000, num, list, 0);
dp实现
function toTheMin2(n,m,arr) {
var dp = {0:0};
for(var i = m; i >= 0; i--){
for(var j = arr[i]; j <= n; j++){
if(dp[j-arr[i]] != undefined){
if(dp[j] == undefined) {
dp[j] = dp[j-arr[i]] + 1;
}else{
dp[j] = Math.min(dp[j], dp[j-arr[i]] + 1);
}
}
}
}
return dp[n];
}
用benchmark跑了一下,暴力解决貌似要快点?
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。