主頁 >  其他 > 回溯演算法在點菜中的應用例子

回溯演算法在點菜中的應用例子

2022-07-22 12:30:48 其他

本人其實內心很抵觸去埋頭刷演算法題,但是有一些演算法在實際業務開發中或者思想上還是值得借鑒的,因此通過這種結合實際場景的小Demo來學習和理解演算法也可能是對演算法提起興趣對抗枯燥的一種方法吧,

在看《劍指Offer》的時候看到回溯章節時,書中的舉一反三提到了回溯演算法可以應用到像點菜這樣的場景中,例如,當客人走進餐館準備吃飯時,服務員會為客人提供一個選單,選單上有所有菜品的價格,如果每道菜只點一份,那么可人有哪些不同的點菜方法剛好將身上的錢全部用完?如果客人只想點k道菜,那么又有哪些不同的點菜方法可以將身上的錢全部用完?如果一道菜可以點多份呢?

結合上面多場景我們可以寫一個程式來模擬它,由于現實中不可能所有客人身上的錢都剛好能點所有的菜,所以我把上面場景中的剛好花完客人身上的錢改為在客人錢的范圍內能點多所有菜的集合,并且我只實作前面兩種策略,即不花光身上的錢的情況下最多只點一道菜可以有多少總策略和不花光身上的錢的情況下指定點菜的數量,并且沒到菜也是最多能點一次,至于后面的一道菜可以點多次實作類似,但意義不大,就不寫了(畢竟平時出去吃飯點菜大部分不會盯著一個菜點好幾份),下面是代碼實作,

視頻演示

嗶哩嗶哩-回溯演算法在點菜中的應用例子演示

代碼實作

為了完整的模擬,我們抽象出客人類和選單類,

客人類

package test;

/**
 * 顧客類
 * @author 胡海龍<www.huhailong.vip>
 *
 */
public class Customer {
	/**
	 * 用戶名
	 */
	private String username;
	/**
	 * 身上總金額 (暫時為了測驗將該型別設定為整型,實際應用中應該使用高精度來修飾)
	 */
	private Integer amount;
	
	//Getter and Setter
	public String getUsername() {
		return username;
	}
	public void setUsername(String username) {
		this.username = username;
	}
	public Integer getAmount() {
		return amount;
	}
	public void setAmount(Integer amount) {
		this.amount = amount;
	}
	
	
}

選單類

package test;

/**
 * 選單類
 * @author 胡海龍<www.huhailong.vip>
 *
 */
public class FoodMenu {
	/**
	 * 菜名
	 */
	private String foodName;
	/**
	 * 價格
	 */
	private Integer price;
	
	//Getter and Setter
	public String getFoodName() {
		return foodName;
	}
	public void setFoodName(String foodName) {
		this.foodName = foodName;
	}
	public Integer getPrice() {
		return price;
	}
	public void setPrice(Integer price) {
		this.price = price;
	}
	
	
}

消費點單類(模擬點單)

package test;

import java.util.HashMap;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;

/**
 * 結賬業務類
 * @author 胡海龍<www.huhailong.vip>
 *
 */
public class CheckOut {
	
	/**
	 * 測驗主方法
	 * @param args
	 */
	public static void main(String[] args) {
		//初始化測驗用戶
		Customer customer = new Customer();
		customer.setUsername("胡海龍");
		customer.setAmount(300);
		
		//使用一個臨時的map資料集模擬資料庫選單表
		Map<String,Integer> foodMenuMap = new HashMap<>();
		foodMenuMap.put("米飯", 4);
		foodMenuMap.put("魚香肉絲", 48);
		foodMenuMap.put("糖醋排骨", 68);
		foodMenuMap.put("京醬肉絲", 48);
		foodMenuMap.put("地鍋雞", 78);
		foodMenuMap.put("螞蟻上樹", 178);
		foodMenuMap.put("毛氏紅燒肉", 79);
		foodMenuMap.put("蒜末拍黃瓜", 12);
		//初始化選單串列
		List<FoodMenu> foodMenuList = new LinkedList<>();
		for(String key : foodMenuMap.keySet()) {
			FoodMenu menu = new FoodMenu();
			menu.setFoodName(key);
			menu.setPrice(foodMenuMap.get(key));
			foodMenuList.add(menu);
		}
		//定義結果集
		List<List<FoodMenu>> result = new LinkedList<>();
		makePolicy1(foodMenuList, 0, customer.getAmount(), new LinkedList<>(), result);
//		makePolicy2(foodMenuList, 0, customer.getAmount(), 2, new LinkedList<>(), result);
		//列印策略
		printPolicy(result);
	}
	
	/**
	 * 策略1 每道菜最多只點一次,在不花光身上所有錢的情況下有哪些點菜的策略
	 * @param foodMenuList 選單集合
	 * @param index		   選單索引
	 * @param total		   顧客身上總錢數
	 * @param tempList	   臨時存盤集合
	 * @param result	   策略結果集合
	 */
	private static void makePolicy1(List<FoodMenu> foodMenuList, int index, int total, LinkedList<FoodMenu> tempList, List<List<FoodMenu>> result) {
		int sum = tempList.stream().mapToInt(FoodMenu::getPrice).sum();
		if(index==foodMenuList.size()&&sum<=total) {
			result.add(new LinkedList<>(tempList));
		}else if(index < foodMenuList.size()) {
			makePolicy1(foodMenuList, index+1, total, tempList, result);
			
			tempList.add(foodMenuList.get(index));
			makePolicy1(foodMenuList, index+1, total, tempList, result);
			tempList.removeLast();
		}
	}
	
	/**
	 * 策略2 每道菜最多只點一次,并且顧客指定點k道菜,在不花光身上所有錢的情況下有哪些點菜的策略
	 * @param foodMenuList 選單集合
	 * @param index		   選單索引
	 * @param total		   顧客身上總錢數
	 * @param k			   指定菜的數量
	 * @param tempList	   臨時存盤集合
	 * @param result	   策略結果集合
	 */
	private static void makePolicy2(List<FoodMenu> foodMenuList, int index, int total, int k, LinkedList<FoodMenu> tempList, List<List<FoodMenu>> result) {
		int sum = tempList.stream().mapToInt(FoodMenu::getPrice).sum();
		if(index==foodMenuList.size()&&sum<=total&&k==tempList.size()) {
			result.add(new LinkedList<>(tempList));
		}else if(index < foodMenuList.size()) {
			makePolicy2(foodMenuList, index+1, total, k, tempList, result);
			
			tempList.add(foodMenuList.get(index));
			makePolicy2(foodMenuList, index+1, total, k, tempList, result);
			tempList.removeLast();
		}
	}
	
	/**
	* 列印策略結果
	*/
	private static void printPolicy(List<List<FoodMenu>> list) {
		int count = 1;
		for(List<FoodMenu> foodMenuList : list) {
			System.out.print("策略"+(count++)+":");
			int totalPrice = 0;
			for(FoodMenu menu : foodMenuList) {
				totalPrice += menu.getPrice();
				System.out.print(menu.getFoodName()+"("+menu.getPrice()+") ");
			}
			System.out.print(" 【總價:】"+totalPrice);
			System.out.println();
		}
	}
}

策略一運行結果

該策略是指用戶每道菜最多只能點一次,在總金額不超過用戶身上帶的總錢數(該demo中設定的是300元)時點所有點菜策略,策略1為0表明客戶沒有進行消費,菜名后面括號中的是菜名的單價,后面會現實沒種策略的總價,運行結果符合上述要求,

策略1: 【總價:】0
策略2:京醬肉絲(48)  【總價:】48
策略3:毛氏紅燒肉(79)  【總價:】79
策略4:毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】127
策略5:蒜末拍黃瓜(12)  【總價:】12
策略6:蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】60
策略7:蒜末拍黃瓜(12) 毛氏紅燒肉(79)  【總價:】91
策略8:蒜末拍黃瓜(12) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】139
策略9:地鍋雞(78)  【總價:】78
策略10:地鍋雞(78) 京醬肉絲(48)  【總價:】126
策略11:地鍋雞(78) 毛氏紅燒肉(79)  【總價:】157
策略12:地鍋雞(78) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】205
策略13:地鍋雞(78) 蒜末拍黃瓜(12)  【總價:】90
策略14:地鍋雞(78) 蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】138
策略15:地鍋雞(78) 蒜末拍黃瓜(12) 毛氏紅燒肉(79)  【總價:】169
策略16:地鍋雞(78) 蒜末拍黃瓜(12) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】217
策略17:糖醋排骨(68)  【總價:】68
策略18:糖醋排骨(68) 京醬肉絲(48)  【總價:】116
策略19:糖醋排骨(68) 毛氏紅燒肉(79)  【總價:】147
策略20:糖醋排骨(68) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】195
策略21:糖醋排骨(68) 蒜末拍黃瓜(12)  【總價:】80
策略22:糖醋排骨(68) 蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】128
策略23:糖醋排骨(68) 蒜末拍黃瓜(12) 毛氏紅燒肉(79)  【總價:】159
策略24:糖醋排骨(68) 蒜末拍黃瓜(12) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】207
策略25:糖醋排骨(68) 地鍋雞(78)  【總價:】146
策略26:糖醋排骨(68) 地鍋雞(78) 京醬肉絲(48)  【總價:】194
策略27:糖醋排骨(68) 地鍋雞(78) 毛氏紅燒肉(79)  【總價:】225
策略28:糖醋排骨(68) 地鍋雞(78) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】273
策略29:糖醋排骨(68) 地鍋雞(78) 蒜末拍黃瓜(12)  【總價:】158
策略30:糖醋排骨(68) 地鍋雞(78) 蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】206
策略31:糖醋排骨(68) 地鍋雞(78) 蒜末拍黃瓜(12) 毛氏紅燒肉(79)  【總價:】237
策略32:糖醋排骨(68) 地鍋雞(78) 蒜末拍黃瓜(12) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】285
策略33:米飯(4)  【總價:】4
策略34:米飯(4) 京醬肉絲(48)  【總價:】52
策略35:米飯(4) 毛氏紅燒肉(79)  【總價:】83
策略36:米飯(4) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】131
策略37:米飯(4) 蒜末拍黃瓜(12)  【總價:】16
策略38:米飯(4) 蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】64
策略39:米飯(4) 蒜末拍黃瓜(12) 毛氏紅燒肉(79)  【總價:】95
策略40:米飯(4) 蒜末拍黃瓜(12) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】143
策略41:米飯(4) 地鍋雞(78)  【總價:】82
策略42:米飯(4) 地鍋雞(78) 京醬肉絲(48)  【總價:】130
策略43:米飯(4) 地鍋雞(78) 毛氏紅燒肉(79)  【總價:】161
策略44:米飯(4) 地鍋雞(78) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】209
策略45:米飯(4) 地鍋雞(78) 蒜末拍黃瓜(12)  【總價:】94
策略46:米飯(4) 地鍋雞(78) 蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】142
策略47:米飯(4) 地鍋雞(78) 蒜末拍黃瓜(12) 毛氏紅燒肉(79)  【總價:】173
策略48:米飯(4) 地鍋雞(78) 蒜末拍黃瓜(12) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】221
策略49:米飯(4) 糖醋排骨(68)  【總價:】72
策略50:米飯(4) 糖醋排骨(68) 京醬肉絲(48)  【總價:】120
策略51:米飯(4) 糖醋排骨(68) 毛氏紅燒肉(79)  【總價:】151
策略52:米飯(4) 糖醋排骨(68) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】199
策略53:米飯(4) 糖醋排骨(68) 蒜末拍黃瓜(12)  【總價:】84
策略54:米飯(4) 糖醋排骨(68) 蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】132
策略55:米飯(4) 糖醋排骨(68) 蒜末拍黃瓜(12) 毛氏紅燒肉(79)  【總價:】163
策略56:米飯(4) 糖醋排骨(68) 蒜末拍黃瓜(12) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】211
策略57:米飯(4) 糖醋排骨(68) 地鍋雞(78)  【總價:】150
策略58:米飯(4) 糖醋排骨(68) 地鍋雞(78) 京醬肉絲(48)  【總價:】198
策略59:米飯(4) 糖醋排骨(68) 地鍋雞(78) 毛氏紅燒肉(79)  【總價:】229
策略60:米飯(4) 糖醋排骨(68) 地鍋雞(78) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】277
策略61:米飯(4) 糖醋排骨(68) 地鍋雞(78) 蒜末拍黃瓜(12)  【總價:】162
策略62:米飯(4) 糖醋排骨(68) 地鍋雞(78) 蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】210
策略63:米飯(4) 糖醋排骨(68) 地鍋雞(78) 蒜末拍黃瓜(12) 毛氏紅燒肉(79)  【總價:】241
策略64:米飯(4) 糖醋排骨(68) 地鍋雞(78) 蒜末拍黃瓜(12) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】289
策略65:魚香肉絲(48)  【總價:】48
策略66:魚香肉絲(48) 京醬肉絲(48)  【總價:】96
策略67:魚香肉絲(48) 毛氏紅燒肉(79)  【總價:】127
策略68:魚香肉絲(48) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】175
策略69:魚香肉絲(48) 蒜末拍黃瓜(12)  【總價:】60
策略70:魚香肉絲(48) 蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】108
策略71:魚香肉絲(48) 蒜末拍黃瓜(12) 毛氏紅燒肉(79)  【總價:】139
策略72:魚香肉絲(48) 蒜末拍黃瓜(12) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】187
策略73:魚香肉絲(48) 地鍋雞(78)  【總價:】126
策略74:魚香肉絲(48) 地鍋雞(78) 京醬肉絲(48)  【總價:】174
策略75:魚香肉絲(48) 地鍋雞(78) 毛氏紅燒肉(79)  【總價:】205
策略76:魚香肉絲(48) 地鍋雞(78) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】253
策略77:魚香肉絲(48) 地鍋雞(78) 蒜末拍黃瓜(12)  【總價:】138
策略78:魚香肉絲(48) 地鍋雞(78) 蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】186
策略79:魚香肉絲(48) 地鍋雞(78) 蒜末拍黃瓜(12) 毛氏紅燒肉(79)  【總價:】217
策略80:魚香肉絲(48) 地鍋雞(78) 蒜末拍黃瓜(12) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】265
策略81:魚香肉絲(48) 糖醋排骨(68)  【總價:】116
策略82:魚香肉絲(48) 糖醋排骨(68) 京醬肉絲(48)  【總價:】164
策略83:魚香肉絲(48) 糖醋排骨(68) 毛氏紅燒肉(79)  【總價:】195
策略84:魚香肉絲(48) 糖醋排骨(68) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】243
策略85:魚香肉絲(48) 糖醋排骨(68) 蒜末拍黃瓜(12)  【總價:】128
策略86:魚香肉絲(48) 糖醋排骨(68) 蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】176
策略87:魚香肉絲(48) 糖醋排骨(68) 蒜末拍黃瓜(12) 毛氏紅燒肉(79)  【總價:】207
策略88:魚香肉絲(48) 糖醋排骨(68) 蒜末拍黃瓜(12) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】255
策略89:魚香肉絲(48) 糖醋排骨(68) 地鍋雞(78)  【總價:】194
策略90:魚香肉絲(48) 糖醋排骨(68) 地鍋雞(78) 京醬肉絲(48)  【總價:】242
策略91:魚香肉絲(48) 糖醋排骨(68) 地鍋雞(78) 毛氏紅燒肉(79)  【總價:】273
策略92:魚香肉絲(48) 糖醋排骨(68) 地鍋雞(78) 蒜末拍黃瓜(12)  【總價:】206
策略93:魚香肉絲(48) 糖醋排骨(68) 地鍋雞(78) 蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】254
策略94:魚香肉絲(48) 糖醋排骨(68) 地鍋雞(78) 蒜末拍黃瓜(12) 毛氏紅燒肉(79)  【總價:】285
策略95:魚香肉絲(48) 米飯(4)  【總價:】52
策略96:魚香肉絲(48) 米飯(4) 京醬肉絲(48)  【總價:】100
策略97:魚香肉絲(48) 米飯(4) 毛氏紅燒肉(79)  【總價:】131
策略98:魚香肉絲(48) 米飯(4) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】179
策略99:魚香肉絲(48) 米飯(4) 蒜末拍黃瓜(12)  【總價:】64
策略100:魚香肉絲(48) 米飯(4) 蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】112
策略101:魚香肉絲(48) 米飯(4) 蒜末拍黃瓜(12) 毛氏紅燒肉(79)  【總價:】143
策略102:魚香肉絲(48) 米飯(4) 蒜末拍黃瓜(12) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】191
策略103:魚香肉絲(48) 米飯(4) 地鍋雞(78)  【總價:】130
策略104:魚香肉絲(48) 米飯(4) 地鍋雞(78) 京醬肉絲(48)  【總價:】178
策略105:魚香肉絲(48) 米飯(4) 地鍋雞(78) 毛氏紅燒肉(79)  【總價:】209
策略106:魚香肉絲(48) 米飯(4) 地鍋雞(78) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】257
策略107:魚香肉絲(48) 米飯(4) 地鍋雞(78) 蒜末拍黃瓜(12)  【總價:】142
策略108:魚香肉絲(48) 米飯(4) 地鍋雞(78) 蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】190
策略109:魚香肉絲(48) 米飯(4) 地鍋雞(78) 蒜末拍黃瓜(12) 毛氏紅燒肉(79)  【總價:】221
策略110:魚香肉絲(48) 米飯(4) 地鍋雞(78) 蒜末拍黃瓜(12) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】269
策略111:魚香肉絲(48) 米飯(4) 糖醋排骨(68)  【總價:】120
策略112:魚香肉絲(48) 米飯(4) 糖醋排骨(68) 京醬肉絲(48)  【總價:】168
策略113:魚香肉絲(48) 米飯(4) 糖醋排骨(68) 毛氏紅燒肉(79)  【總價:】199
策略114:魚香肉絲(48) 米飯(4) 糖醋排骨(68) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】247
策略115:魚香肉絲(48) 米飯(4) 糖醋排骨(68) 蒜末拍黃瓜(12)  【總價:】132
策略116:魚香肉絲(48) 米飯(4) 糖醋排骨(68) 蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】180
策略117:魚香肉絲(48) 米飯(4) 糖醋排骨(68) 蒜末拍黃瓜(12) 毛氏紅燒肉(79)  【總價:】211
策略118:魚香肉絲(48) 米飯(4) 糖醋排骨(68) 蒜末拍黃瓜(12) 毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】259
策略119:魚香肉絲(48) 米飯(4) 糖醋排骨(68) 地鍋雞(78)  【總價:】198
策略120:魚香肉絲(48) 米飯(4) 糖醋排骨(68) 地鍋雞(78) 京醬肉絲(48)  【總價:】246
策略121:魚香肉絲(48) 米飯(4) 糖醋排骨(68) 地鍋雞(78) 毛氏紅燒肉(79)  【總價:】277
策略122:魚香肉絲(48) 米飯(4) 糖醋排骨(68) 地鍋雞(78) 蒜末拍黃瓜(12)  【總價:】210
策略123:魚香肉絲(48) 米飯(4) 糖醋排骨(68) 地鍋雞(78) 蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】258
策略124:魚香肉絲(48) 米飯(4) 糖醋排骨(68) 地鍋雞(78) 蒜末拍黃瓜(12) 毛氏紅燒肉(79)  【總價:】289
策略125:螞蟻上樹(178)  【總價:】178
策略126:螞蟻上樹(178) 京醬肉絲(48)  【總價:】226
策略127:螞蟻上樹(178) 毛氏紅燒肉(79)  【總價:】257
策略128:螞蟻上樹(178) 蒜末拍黃瓜(12)  【總價:】190
策略129:螞蟻上樹(178) 蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】238
策略130:螞蟻上樹(178) 蒜末拍黃瓜(12) 毛氏紅燒肉(79)  【總價:】269
策略131:螞蟻上樹(178) 地鍋雞(78)  【總價:】256
策略132:螞蟻上樹(178) 地鍋雞(78) 蒜末拍黃瓜(12)  【總價:】268
策略133:螞蟻上樹(178) 糖醋排骨(68)  【總價:】246
策略134:螞蟻上樹(178) 糖醋排骨(68) 京醬肉絲(48)  【總價:】294
策略135:螞蟻上樹(178) 糖醋排骨(68) 蒜末拍黃瓜(12)  【總價:】258
策略136:螞蟻上樹(178) 米飯(4)  【總價:】182
策略137:螞蟻上樹(178) 米飯(4) 京醬肉絲(48)  【總價:】230
策略138:螞蟻上樹(178) 米飯(4) 毛氏紅燒肉(79)  【總價:】261
策略139:螞蟻上樹(178) 米飯(4) 蒜末拍黃瓜(12)  【總價:】194
策略140:螞蟻上樹(178) 米飯(4) 蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】242
策略141:螞蟻上樹(178) 米飯(4) 蒜末拍黃瓜(12) 毛氏紅燒肉(79)  【總價:】273
策略142:螞蟻上樹(178) 米飯(4) 地鍋雞(78)  【總價:】260
策略143:螞蟻上樹(178) 米飯(4) 地鍋雞(78) 蒜末拍黃瓜(12)  【總價:】272
策略144:螞蟻上樹(178) 米飯(4) 糖醋排骨(68)  【總價:】250
策略145:螞蟻上樹(178) 米飯(4) 糖醋排骨(68) 京醬肉絲(48)  【總價:】298
策略146:螞蟻上樹(178) 米飯(4) 糖醋排骨(68) 蒜末拍黃瓜(12)  【總價:】262
策略147:螞蟻上樹(178) 魚香肉絲(48)  【總價:】226
策略148:螞蟻上樹(178) 魚香肉絲(48) 京醬肉絲(48)  【總價:】274
策略149:螞蟻上樹(178) 魚香肉絲(48) 蒜末拍黃瓜(12)  【總價:】238
策略150:螞蟻上樹(178) 魚香肉絲(48) 蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】286
策略151:螞蟻上樹(178) 魚香肉絲(48) 糖醋排骨(68)  【總價:】294
策略152:螞蟻上樹(178) 魚香肉絲(48) 米飯(4)  【總價:】230
策略153:螞蟻上樹(178) 魚香肉絲(48) 米飯(4) 京醬肉絲(48)  【總價:】278
策略154:螞蟻上樹(178) 魚香肉絲(48) 米飯(4) 蒜末拍黃瓜(12)  【總價:】242
策略155:螞蟻上樹(178) 魚香肉絲(48) 米飯(4) 蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】290
策略156:螞蟻上樹(178) 魚香肉絲(48) 米飯(4) 糖醋排骨(68)  【總價:】298

策略二運行結果

策略二是在策略1的基礎上指定了點菜數目,該Demo中指定的菜數量是2,因此該策略集中都是數量為2的策略并且不超過用戶所帶總金額(300元),運行結果符合上述要求,

策略1:毛氏紅燒肉(79) 京醬肉絲(48)  【總價:】127
策略2:蒜末拍黃瓜(12) 京醬肉絲(48)  【總價:】60
策略3:蒜末拍黃瓜(12) 毛氏紅燒肉(79)  【總價:】91
策略4:地鍋雞(78) 京醬肉絲(48)  【總價:】126
策略5:地鍋雞(78) 毛氏紅燒肉(79)  【總價:】157
策略6:地鍋雞(78) 蒜末拍黃瓜(12)  【總價:】90
策略7:糖醋排骨(68) 京醬肉絲(48)  【總價:】116
策略8:糖醋排骨(68) 毛氏紅燒肉(79)  【總價:】147
策略9:糖醋排骨(68) 蒜末拍黃瓜(12)  【總價:】80
策略10:糖醋排骨(68) 地鍋雞(78)  【總價:】146
策略11:米飯(4) 京醬肉絲(48)  【總價:】52
策略12:米飯(4) 毛氏紅燒肉(79)  【總價:】83
策略13:米飯(4) 蒜末拍黃瓜(12)  【總價:】16
策略14:米飯(4) 地鍋雞(78)  【總價:】82
策略15:米飯(4) 糖醋排骨(68)  【總價:】72
策略16:魚香肉絲(48) 京醬肉絲(48)  【總價:】96
策略17:魚香肉絲(48) 毛氏紅燒肉(79)  【總價:】127
策略18:魚香肉絲(48) 蒜末拍黃瓜(12)  【總價:】60
策略19:魚香肉絲(48) 地鍋雞(78)  【總價:】126
策略20:魚香肉絲(48) 糖醋排骨(68)  【總價:】116
策略21:魚香肉絲(48) 米飯(4)  【總價:】52
策略22:螞蟻上樹(178) 京醬肉絲(48)  【總價:】226
策略23:螞蟻上樹(178) 毛氏紅燒肉(79)  【總價:】257
策略24:螞蟻上樹(178) 蒜末拍黃瓜(12)  【總價:】190
策略25:螞蟻上樹(178) 地鍋雞(78)  【總價:】256
策略26:螞蟻上樹(178) 糖醋排骨(68)  【總價:】246
策略27:螞蟻上樹(178) 米飯(4)  【總價:】182
策略28:螞蟻上樹(178) 魚香肉絲(48)  【總價:】226

總結

該案例是回溯演算法在現實場景中的一個簡單的應用demo,當然實際的業務中可能會有各式各樣的場景,只要有類似的程序——求問題的解會分成若干步,每一步又面臨同樣的選擇,此時可以考慮使用回溯演算法來解決,需要注意的是回溯演算法中重要的是記得要狀態回溯,想上面代碼中的removeLast()方法就是狀態回溯的步驟,

個人主頁:歡迎訪問

以上的演算法題目對應LeetCode的題號:

  • 劍指 Offer II 079. 所有子集
  • 劍指 Offer II 080. 含有 k 個元素的組合

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/500076.html

標籤:其他

上一篇:LeetCode - 整數反轉

下一篇:PySide6/PyQt開發xml編輯器(1)

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more