/** * File: fractional_knapsack.dart * Created Time: 2023-08-11 * Author: liuyuxin (gvenusleo@gmail.com) */ /* Item */ class Item { int w; // Item weight int v; // Item value Item(this.w, this.v); } /* Fractional knapsack: Greedy */ double fractionalKnapsack(List wgt, List val, int cap) { // Create an item list, containing two properties: weight, value List items = List.generate(wgt.length, (i) => Item(wgt[i], val[i])); // Sort by unit value item.v / item.w from high to low items.sort((a, b) => (b.v / b.w).compareTo(a.v / a.w)); // Loop for greedy selection double res = 0; for (Item item in items) { if (item.w <= cap) { // If the remaining capacity is sufficient, put the entire item into the knapsack res += item.v; cap -= item.w; } else { // If the remaining capacity is insufficient, put part of the item into the knapsack res += item.v / item.w * cap; // No remaining capacity left, thus break the loop break; } } return res; } /* Driver Code */ void main() { List wgt = [10, 20, 30, 40, 50]; List val = [50, 120, 150, 210, 240]; int cap = 50; // Greedy algorithm double res = fractionalKnapsack(wgt, val, cap); print("Maximum value of items without exceeding bag capacity = $res"); }