-
Notifications
You must be signed in to change notification settings - Fork 1k
/
Copy pathFractionalKnapsack.java
124 lines (89 loc) · 3.16 KB
/
FractionalKnapsack.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
/* You are given two lists of integers weights and values which have
the same length and an integer capacity. weights[i] and values[i]
represent the weight and value of the ith item. Given that you can
take at most capacity weights, and that you can take a fraction of
an item's weight with proportionate value, return the maximum amount
of value you can get, rounded down to the nearest integer. */
import java.util.*;
public class FractionalKnapsack {
/* Pair class used to store the weight, value, and ratio of value:weight of a particular item */
static class Pair{
int wt;
int val;
double ratio;
}
/* Used to sort all items based on their value:weight ratio in descending order */
static class SortByRatio implements Comparator<Pair>{
public int compare(Pair a, Pair b){
if(b.ratio >= a.ratio){
return 1;
}else{
return -1;
}
}
}
/* Function created to get maximum Profit */
public static int getMaxProfit(int[] weights, int[] values, int capacity) {
/* Creating a pairs array which stores all the items according to their weight,value and ratio */
Pair pairs[] = new Pair[weights.length];
/* Adding items to the pairs array */
for(int i=0; i<weights.length; i++){
Pair p = new Pair();
p.val = values[i];
p.wt = weights[i];
double wt = weights[i];
double val = values[i];
p.ratio = val/wt;
pairs[i] = p;
}
/* Sorting the pairs array based on their ratio */
Arrays.sort(pairs, new SortByRatio());
/* Initializing an ans variable */
int ans = 0;
/* Traversing through all items in the array */
for(Pair p : pairs){
/* Including a particular item, if we can accommodate it */
if(p.wt <= capacity){
ans += p.val;
capacity-=p.wt;
}
/* Taking the fractional value of the item if we cannot accommodate it */
else{
ans += (p.ratio * capacity);
/* Breaking from loop as we reached our peak capacity */
break;
}
}
return ans;
}
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
int items = input.nextInt();
int weights[] = new int[items];
int values[] = new int[items];
int capacity = 0;
for(int i=0; i<items; i++){
weights[i] = input.nextInt();
}
for(int i=0; i<items; i++){
values[i] = input.nextInt();
}
capacity = input.nextInt();
input.close();
System.out.println(getMaxProfit(weights, values, capacity));
}
}
/*
Input
weights = [5, 6, 2]
values = [100, 100, 1]
capacity = 8
Output
150
Explanation
Take the item with weight 5 and value 100, we are left with capacity 3
Take half of the item with weight 6, so it's value would become 50.
Thereby getting a maximum profit of 150
Time Complexity : O(N)
Space Complexity : O(N)
*/