-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathKnapsack.java
More file actions
141 lines (126 loc) · 3.8 KB
/
Knapsack.java
File metadata and controls
141 lines (126 loc) · 3.8 KB
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
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
/*
* javac Knapsack.java
* java Knapsack
*/
import java.io.*;
import java.util.*;
import java.math.*;
class KnapsackAlgo{
int[] v;
int[] w;
int[][] A;
int W;
int nElems;
public KnapsackAlgo(int W, int numOfItems, boolean big){
v = new int[numOfItems + 1];
w = new int[numOfItems + 1];
if(big == true){
A = new int[2][W+1];
} else{
A = new int[v.length][W + 1];
}
this.W = W;
nElems = 1;
}
public void insert(int v_i, int w_i){
v[nElems] = v_i;
w[nElems] = w_i;
nElems++;
}
public void display_v(){
for(int i = 1; i < v.length; i++){
System.out.print(v[i] + " ");
}
System.out.println("");
}
public void display_w(){
for(int x = 1; x < w.length; x++){
System.out.print(w[x] + " ");
}
System.out.println("");
}
public int[][] solve(){
for(int x = 0; x < A[0].length; x++){
A[0][x] = 0;
}
int max = 0;
for(int i = 1; i < A.length; i++){
for(int x = 0; x < A[0].length; x++){
if(w[i] > x){
A[i][x] = A[i-1][x];
} else{
//System.out.println("v[i] = " + v[i]);
A[i][x] = Math.max( A[i-1][x] , A[i-1][x - w[i]] + v[i]);
}
if(A[i][x] > max){
max = A[i][x];
}
}
}
System.out.println("Max = " + max);
return A;
}
// for knapsack_big problem, only have A[0] and A[1], since only these 2 columns are relevant
public int[][] solveBig(){
for(int x = 0; x < A[0].length; x++){
A[0][x] = 0;
}
int max = 0;
for(int i = 1; i < nElems; i++){
for(int x = 0; x < A[0].length; x++){
int j = 0;
if(w[i] > x){
A[1][x] = A[j][x];
} else{
A[1][x] = Math.max(A[j][x], A[j][x-w[i]] + v[i]);
}
if(A[1][x] > max){
max = A[1][x];
}
}
// copy A[1] to A[0]
for(int k = 0; k < A[0].length; k++){
A[0][k] = A[1][k];
}
}
System.out.println("Max (large knapack problem) = " + max);
return A;
}
public void display(){
for(int x = A[0].length- 1; x >= 0; x--){
for(int i = 0; i < A.length; i++){
//System.out.print(A[i][x] + " ");
System.out.print(A[i][x] + " ");
}
System.out.println("");
}
}
}
class Knapsack{
public static void main(String[] args){
try{
KnapsackAlgo ka = read_file_and_populate("knapsack1.txt", false);
ka.solve();
//ka.solve();
//ka.display();
//ka.display_v();
//ka.display_w();
KnapsackAlgo ka_big = read_file_and_populate("knapsack_big.txt", true);
ka_big.solveBig();
} catch(IOException e){
e.printStackTrace();
}
}
public static KnapsackAlgo read_file_and_populate(String file_loc, boolean big) throws IOException{
FileInputStream fil = new FileInputStream(file_loc);
BufferedReader br = new BufferedReader(new InputStreamReader(fil));
String element = br.readLine();
String[] line = element.split("\\s+");
KnapsackAlgo ka = new KnapsackAlgo(Integer.parseInt(line[0]), Integer.parseInt(line[1]),big);
while( (element = br.readLine()) != null ){
line = element.split("\\s+");
ka.insert(Integer.parseInt(line[0]), Integer.parseInt(line[1]));
}
return ka;
}
}