<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
package com.platform.modules.alg.alglib.p933; import java.util.Arrays; import java.util.PriorityQueue; public class P933 { public static final int N = 10; // 記錄最優解 boolean bestx[] = new boolean[N]; // 輔助陣列,用於儲存排序後的重量和價值 private int w[] = new int[N]; private int v[] = new int[N]; Goods goods[] = new Goods[N]; Object S[] = new Object[N]; // 用來記錄最優解 Integer bestp; // 為揹包的最大容量 int W; // 為物品的個數。 int n; // 為所有物品的總重量。 int sumw; // 為所有物品的總價值 int sumv; public String output = ""; public P933() { for (int i = 0; i < goods.length; i++) { goods[i] = new Goods(); } for (int i = 0; i < S.length; i++) { S[i] = new Object(); } } // 計算節點的上界 double Bound(Node tnode) { // 已裝入揹包物品價值 double maxvalue = tnode.cp; int t = tnode.id; // 排序後序號 double left = tnode.rw; // 剩餘容量 while (t <= n && w[t] <= left) { maxvalue += v[t]; left -= w[t++]; } if (t <= n) maxvalue += ((double) (v[t])) / w[t] * left; return maxvalue; } public String cal(String input) { String[] line = input.split("n"); String[] words = line[0].split(" "); // 物品的個數和揹包的容量 n = Integer.parseInt(words[0]); W = Integer.parseInt(words[1]); bestp = 0; // 用來記錄最優解 sumw = 0; // sumw 為所有物品的總重量。 sumv = 0; // sumv為所有物品的總價值 words = line[1].split(" "); for (int i = 1; i <= words.length / 2; i++) { // 輸入每個物品的重量和價值,用空格分開 goods[i].weight = Integer.parseInt(words[2 * i - 2]); goods[i].value = Integer.parseInt(words[2 * i - 1]); sumw += goods[i].weight; sumv += goods[i].value; S[i - 1].id = i; S[i - 1].d = 1.0 * goods[i].value / goods[i].weight; } if (sumw <= W) { bestp = sumv; output = bestp.toString(); return output; } Arrays.sort(S); // 按價值重量比非遞增排序 for (int i = 1; i <= n; i++) {//把排序後的資料傳遞給輔助陣列 w[i] = goods[S[i - 1].id].weight; v[i] = goods[S[i - 1].id].value; } priorbfs();//優先佇列分支限界法 output += bestp + "n"; for (int i = 1; i <= n; i++) { // 輸出最優解 if (bestx[i]) output += S[i - 1].id + " "; // 輸出原物品序號(排序前的) } return output; } // 優先佇列式分支限界法 int priorbfs() { // 當前處理的物品序號t,當前裝入揹包物品價值tcp,當前剩餘容量trw int t, tcp, trw; double tup; // 當前價值上界 tup PriorityQueue<Node> q = new PriorityQueue<>(); // 優先佇列 q.add(new Node(0, sumv, W, 1)); // 初始化,根結點加入優先佇列 while (!q.isEmpty()) { // 定義三個結點型變數 Node livenode; Node lchild = new Node(); Node rchild = new Node(); livenode = q.peek(); // 取出隊頭元素作為當前擴充套件結點 livenode q.poll(); // 隊頭元素出隊 t = livenode.id; // 當前處理的物品序號 // 搜到最後一個物品的時候不需要往下搜尋。 // 如果當前的揹包沒有剩餘容量(已經裝滿)了,不再擴充套件。 if (t > n || livenode.rw == 0) { if (livenode.cp >= bestp) { // 更新最優解和最優值 for (int i = 1; i <= n; i++) bestx[i] = livenode.x[i]; bestp = livenode.cp; } continue; } if (livenode.up < bestp)//如果不滿足不再擴充套件 continue; tcp = livenode.cp; //當前揹包中的價值 trw = livenode.rw; //揹包剩餘容量 if (trw >= w[t]) { //擴充套件左孩子,滿足約束條件,可以放入揹包 lchild.cp = tcp + v[t]; lchild.rw = trw - w[t]; lchild.id = t + 1; tup = Bound(lchild); //計算左孩子上界 lchild = new Node(lchild.cp, tup, lchild.rw, lchild.id); for (int i = 1; i <= n; i++)//複製以前的解向量 lchild.x[i] = livenode.x[i]; lchild.x[t] = true; if (lchild.cp > bestp)//比最優值大才更新 bestp = lchild.cp; q.add(lchild);//左孩子入隊 } rchild.cp = tcp; rchild.rw = trw; rchild.id = t + 1; tup = Bound(rchild);//計算右孩子上界 if (tup >= bestp) {//擴充套件右孩子,滿足限界條件,不放入 rchild = new Node(tcp, tup, trw, t + 1); for (int i = 1; i <= n; i++)//複製以前的解向量 rchild.x[i] = livenode.x[i]; rchild.x[t] = false; q.add(rchild);//右孩子入隊 } } return bestp;//返回最優值。 } } // 定義結點。每個節點來記錄當前的解。 class Node implements Comparable<Node> { int cp; // cp 為當前裝入揹包的物品總價值 double up; // 價值上界 int rw; // 剩餘容量 int id; // 物品號 boolean x[] = new boolean[P933.N]; // 解向量 Node() { } Node(int _cp, double _up, int _rw, int _id) { cp = _cp; up = _up; rw = _rw; id = _id; } @Override public int compareTo(Node o) { return (this.up - o.up) > 0 ? 1 : -1; } } // 物品 class Goods { int weight; // 重量 int value; // 價值 } // 輔助物品結構體,用於按單位重量價值(價值/重量比)排序 class Object implements Comparable { int id; // 序號 double d; // 單位重量價值 @Override public int compareTo(java.lang.Object o) { return this.d > ((Object) o).d ? -1 : 1; } }
到此這篇關於Java實現優先佇列式廣度優先搜尋演演算法的範例程式碼的文章就介紹到這了,更多相關Java廣度優先搜尋演演算法內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45