-
Notifications
You must be signed in to change notification settings - Fork 363
/
Copy pathrod_cutting.hpp
83 lines (69 loc) · 1.96 KB
/
rod_cutting.hpp
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
/*
Rod cutting problem
--------------------
Given a rod of length N units and an array of prices
that contains prices of all pieces of size smaller than N.
Determine the maximum value obtainable by cutting up
the rod and selling the pieces
Time complexity
---------------
O(N^2)
Space complexity
----------------
O(N)
Author
------
Nikolaus Fedurko (@B1Z0N)
*/
#ifndef ROD_CUTTING_HPP
#define ROD_CUTTING_HPP
#include <vector>
/**
* Recursive helper function
*/
std::size_t __rod_cutting( const std::vector<std::size_t>& costs, std::vector<std::size_t>& visited, std::size_t length) {
// whole unit, can't delete
if ( length == 1 ) {
return visited[0];
}
// try to sell it as is, not cutting
std::size_t cost = costs[ length - 1 ];
std::size_t next_cost;
/**
* loop to check only half,
* because other half is symmetric
* try cutting 1, 2, 3 ...
* and find optimal
*/
for ( std::size_t i = 1; i <= length / 2; i++ ) {
// if we've already found - use it
if ( visited[ length - i - 1 ] != -1 ) {
next_cost = visited[ length - i - 1 ];
}
// if no - go find it
else {
next_cost = __rod_cutting( costs, visited, length - i );
}
// plus cost of the piece we are cutting
next_cost += costs[ i - 1 ];
// assign maximal value
if ( cost < next_cost ) {
cost = next_cost;
}
}
// don't forget to set this
// as visited
visited[length - 1] = cost;
return cost;
}
/**
* Solution function
*/
std::size_t rod_cutting( std::vector<std::size_t> costs ) {
// vector of already found optimal costs
std::vector<std::size_t> visited ( costs.size(), -1 );
// rod of length 1 is optimally sold at cost of itself
visited[0] = costs[0];
return __rod_cutting( costs, visited, costs.size() );
}
#endif // ROD_CUTTING_HPP