- Notifications
You must be signed in to change notification settings - Fork 19.9k
/
Copy pathRodCutting.java
32 lines (26 loc) · 885 Bytes
/
RodCutting.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
packagecom.thealgorithms.dynamicprogramming;
/**
* A DynamicProgramming solution for Rod cutting problem Returns the best
* obtainable price for a rod of length n and price[] as prices of different
* pieces
*/
publicclassRodCutting {
privatestaticintcutRod(int[] price, intn) {
int[] val = newint[n + 1];
val[0] = 0;
for (inti = 1; i <= n; i++) {
intmax_val = Integer.MIN_VALUE;
for (intj = 0; j < i; j++) {
max_val = Math.max(max_val, price[j] + val[i - j - 1]);
}
val[i] = max_val;
}
returnval[n];
}
// main function to test
publicstaticvoidmain(String[] args) {
int[] arr = newint[] { 2, 5, 13, 19, 20 };
intresult = cutRod(arr, arr.length);
System.out.println("Maximum Obtainable Value is " + result);
}
}