-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrodCuttingDYNAMIC(inludes backtrack).cpp
116 lines (90 loc) · 2.13 KB
/
rodCuttingDYNAMIC(inludes backtrack).cpp
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
/*
The complete rod-cutting problem to maximise the profit earned.
This version includes the backtrack feature too that is used to
identify which items to select in order to get the optimal profit.
Pointing any error out won't go unappreciated :)
*/
/*
Author: @coder_nigga
13 July 2017
10:14 PM IST
*/
/*
What we actually do:
1. We just introduce a list that keeps track of the value changes
or 2. We traverse the formed array backwards and note the changes as per the algorithm
The second one seems pretty easy and we are gonna follow it(mostly because I haven't come
up with a way to implement the first one)...[LOL]
*/
#include <bits/stdc++.h>
#define MAX_ROW 100
#define MAX_COL 110
#define MAX 110
using namespace std;
int main(){
int t;
int a[MAX_ROW][MAX_COL];
for(int i=0; i<MAX_ROW; i++){
a[i][0]=0;
}
for(int j=0; j<MAX_COL; j++){
a[0][j]=0;
}
cout<<"No of test cases: ";
cin>>t;
while(t--){
int len;
cout<<"Enter the length of the rod : ";
cin>>len;
int n;
cout<<"Enter no of cutting possibilities: ";
cin>>n;
int val[MAX];
for(int i=1; i<=n; i++){
cout<<"Enter the profit value of a piece of length "<<i<<": ";
cin>>val[i];
}
for(int i=0; i<=n; i++){
for(int j=0; j<=len; j++){
if(i>j){
a[i][j]=a[i-1][j];
}
else{
if(i==1){
a[i][j]=val[i]*j;
}
/*ERROR ZONE*/
else{
a[i][j]=max(a[i-1][j] , val[i]+a[i][j-i]);
}
/*ERROR ZONE*/
}
if(i>0)
printf(" %d ", a[i][j]);
}
if(i>0)
printf("\n\n");
}
/*FOR BACKTRACK*/
int k=0;
int sizes[MAX];
int row = n;
int col = len;
while(row && col){
if(a[row][col]==a[row-1][col]){
row--;
}
else{
sizes[k++]=row;
col=col-row;
}
}
cout<<"The required max possible profit is :"<<a[n][len]<<endl;
cout<<"And the sizes are : ";
for(int i=0; i<k; i++){
printf("%d, ", sizes[i]);
}
cout<<endl<<endl;
}
return 0;
}