0% found this document useful (0 votes)
24 views5 pages

BEST - Fractional Knapsack - Tutorialspoint

Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
24 views5 pages

BEST - Fractional Knapsack - Tutorialspoint

Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 5

1/28/2021 DAA - Fractional Knapsack - Tutorialspoint

DAA - Fractional Knapsack

The Greedy algorithm could be understood very well with a well-known problem referred to as Knapsack problem. Although the same
problem could be solved by employing other algorithmic approaches, Greedy approach solves Fractional Knapsack problem
reasonably in a good time. Let us discuss the Knapsack problem in detail.

Knapsack Problem
Given a set of items, each with a weight and a value, determine a subset of items to include in a collection so that the total weight is
less than or equal to a given limit and the total value is as large as possible.
The knapsack problem is in combinatorial optimization problem. It appears as a subproblem in many, more complex mathematical
models of real-world problems. One general approach to difficult problems is to identify the most restrictive constraint, ignore the
others, solve a knapsack problem, and somehow adjust the solution to satisfy the ignored constraints.

Applications
In many cases of resource allocation along with some constraint, the problem can be derived in a similar way of Knapsack problem.
Following is a set of example.
Finding the least wasteful way to cut raw materials
portfolio optimization
Cutting stock problems

Problem Scenario
A thief is robbing a store and can carry a maximal weight of W into his knapsack. There are n items available in the store and weight
of ith item is wi and its profit is pi. What items should the thief take?
In this context, the items should be selected in such a way that the thief will carry those items for which he will gain maximum profit.
Hence, the objective of the thief is to maximize the profit.

https://www.tutorialspoint.com/design_and_analysis_of_algorithms/design_and_analysis_of_algorithms_fractional_knapsack.htm#:~:text=problem in detail.-,Knapsack Problem,is in combinatorial optimi… 1/5


1/28/2021 DAA - Fractional Knapsack - Tutorialspoint

Based on the nature of the items, Knapsack problems are categorized as


Fractional Knapsack
Knapsack

Fractional Knapsack
In this case, items can be broken into smaller pieces, hence the thief can select fractions of items.
According to the problem statement,
There are n items in the store

Weight of ith item w


wii >
> 0
0

Profit for ith item p


pii >
> 0
0 and

Capacity of the Knapsack is W


In this version of Knapsack problem, items can be broken into smaller pieces. So, the thief may take only a fraction xi of ith item.

0
0 ⩽
⩽ x
xii ⩽
⩽ 1
1

The ith item contributes the weight x


xii .. w
wii to the total weight in the knapsack and profit x
xii .. p
pii to the total profit.

Hence, the objective of this algorithm is to

n
n

m
maax
xiim
miiz
zee ∑
∑((x
xii .. p
pii)
)

n
n==1
1

subject to constraint,

https://www.tutorialspoint.com/design_and_analysis_of_algorithms/design_and_analysis_of_algorithms_fractional_knapsack.htm#:~:text=problem in detail.-,Knapsack Problem,is in combinatorial optimi… 2/5


1/28/2021 DAA - Fractional Knapsack - Tutorialspoint

n
n


∑((x
xii .. w
wii)
) ⩽
⩽ W
W

n
n==1
1

It is clear that an optimal solution must fill the knapsack exactly, otherwise we could add a fraction of one of the remaining items and
increase the overall profit.
Thus, an optimal solution can be obtained by

n
n


∑((x
xii .. w
wii)
) =
= W
W

n
n==1
1

p
pii p
pii+
+11 p
pii
In this context, first we need to sort those items according to the value of w
, so that w
≤ . Here, x is an array to store
wii wii+
+11 w
wii

the fraction of items.

Algorithm: Greedy-Fractional-Knapsack (w[1..n], p[1..n], W)


for i = 1 to n
do x[i] = 0
weight = 0
for i = 1 to n
if weight + w[i] ≤ W then
x[i] = 1
weight = weight + w[i]
else
x[i] = (W - weight) / w[i]
weight = W
break
return x

Analysis
https://www.tutorialspoint.com/design_and_analysis_of_algorithms/design_and_analysis_of_algorithms_fractional_knapsack.htm#:~:text=problem in detail.-,Knapsack Problem,is in combinatorial optimi… 3/5
1/28/2021 DAA - Fractional Knapsack - Tutorialspoint

p
pii
If the provided items are already sorted into a decreasing order of w
, then the whileloop takes a time in O(n); Therefore, the total
wii

time including the sort is in O(n logn).

Example
Let us consider that the capacity of the knapsack W = 60 and the list of provided items are shown in the following table −

Item A B C D

Profit 280 100 120 120

Weight 40 10 20 24

p
pii
Ratio (
(
w
)
)
7 10 6 5
wii

p
pii
As the provided items are not sorted based on w
. After sorting, the items are as shown in the following table.
wii

Item B A C D

Profit 100 280 120 120

Weight 10 40 20 24

p
pii
Ratio (
(
w
)
)
10 7 6 5
wii

Solution

https://www.tutorialspoint.com/design_and_analysis_of_algorithms/design_and_analysis_of_algorithms_fractional_knapsack.htm#:~:text=problem in detail.-,Knapsack Problem,is in combinatorial optimi… 4/5


1/28/2021 DAA - Fractional Knapsack - Tutorialspoint

p
pii
After sorting all the items according to w
wii
. First all of B is chosen as weight of B is less than the capacity of the knapsack. Next,

item A is chosen, as the available capacity of the knapsack is greater than the weight of A. Now, C is chosen as the next item.
However, the whole item cannot be chosen as the remaining capacity of the knapsack is less than the weight of C.

Hence, fraction of C (i.e. (60 − 50)/20) is chosen.


Now, the capacity of the Knapsack is equal to the selected items. Hence, no more item can be selected.

The total weight of the selected items is 10 + 40 + 20 * (10/20) = 60


And the total profit is 100 + 280 + 120 * (10/20) = 380 + 60 = 440

This is the optimal solution. We cannot gain more profit selecting any different combination of items.

https://www.tutorialspoint.com/design_and_analysis_of_algorithms/design_and_analysis_of_algorithms_fractional_knapsack.htm#:~:text=problem in detail.-,Knapsack Problem,is in combinatorial optimi… 5/5

You might also like