mirror of
https://github.com/TheAlgorithms/Ruby
synced 2025-02-06 08:46:04 +01:00
Merge pull request #177 from TheAlgorithms/ones-and-zeroes
Ones and Zeros: Dynamic Programming approach
This commit is contained in:
commit
b59a46c05e
2 changed files with 57 additions and 0 deletions
|
@ -87,6 +87,7 @@
|
||||||
* [Count Sorted Vowel Strings](https://github.com/TheAlgorithms/Ruby/blob/master/dynamic_programming/count_sorted_vowel_strings.rb)
|
* [Count Sorted Vowel Strings](https://github.com/TheAlgorithms/Ruby/blob/master/dynamic_programming/count_sorted_vowel_strings.rb)
|
||||||
* [Fibonacci](https://github.com/TheAlgorithms/Ruby/blob/master/dynamic_programming/fibonacci.rb)
|
* [Fibonacci](https://github.com/TheAlgorithms/Ruby/blob/master/dynamic_programming/fibonacci.rb)
|
||||||
* [House Robber](https://github.com/TheAlgorithms/Ruby/blob/master/dynamic_programming/house_robber.rb)
|
* [House Robber](https://github.com/TheAlgorithms/Ruby/blob/master/dynamic_programming/house_robber.rb)
|
||||||
|
* [Ones And Zeros](https://github.com/TheAlgorithms/Ruby/blob/master/dynamic_programming/ones_and_zeros.rb)
|
||||||
* [Pascal Triangle Ii](https://github.com/TheAlgorithms/Ruby/blob/master/dynamic_programming/pascal_triangle_ii.rb)
|
* [Pascal Triangle Ii](https://github.com/TheAlgorithms/Ruby/blob/master/dynamic_programming/pascal_triangle_ii.rb)
|
||||||
|
|
||||||
## Maths
|
## Maths
|
||||||
|
|
56
dynamic_programming/ones_and_zeros.rb
Normal file
56
dynamic_programming/ones_and_zeros.rb
Normal file
|
@ -0,0 +1,56 @@
|
||||||
|
# You are given an array of binary strings strs and two integers m and n.
|
||||||
|
#
|
||||||
|
# Return the size of the largest subset of strs such that there are at most m 0's and n 1's in the subset.
|
||||||
|
#
|
||||||
|
# A set x is a subset of a set y if all elements of x are also elements of y.
|
||||||
|
#
|
||||||
|
# Example 1:
|
||||||
|
#
|
||||||
|
# Input: strs = ["10","0001","111001","1","0"], m = 5, n = 3
|
||||||
|
# Output: 4
|
||||||
|
# Explanation: The largest subset with at most 5 0's and 3 1's is {"10", "0001", "1", "0"}, so the answer is 4.
|
||||||
|
# Other valid but smaller subsets include {"0001", "1"} and {"10", "1", "0"}.
|
||||||
|
# {"111001"} is an invalid subset because it contains 4 1's, greater than the maximum of 3.
|
||||||
|
#
|
||||||
|
# Example 2:
|
||||||
|
#
|
||||||
|
# Input: strs = ["10","0","1"], m = 1, n = 1
|
||||||
|
# Output: 2
|
||||||
|
# Explanation: The largest subset is {"0", "1"}, so the answer is 2.
|
||||||
|
|
||||||
|
#
|
||||||
|
# Approach #1 Dynamic Programming
|
||||||
|
#
|
||||||
|
|
||||||
|
# @param {String[]} strs
|
||||||
|
# @param {Integer} m
|
||||||
|
# @param {Integer} n
|
||||||
|
# @return {Integer}
|
||||||
|
def find_max_form(strs, m, n)
|
||||||
|
dp = (m + 1).times.map { [0] * (n + 1) }
|
||||||
|
|
||||||
|
strs.each do |str|
|
||||||
|
zeros = str.count('0')
|
||||||
|
ones = str.count('1')
|
||||||
|
|
||||||
|
m.downto(zeros) do |i|
|
||||||
|
n.downto(ones) do |j|
|
||||||
|
dp[i][j] = [dp[i][j], dp[i - zeros][j - ones] + 1].max
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
dp[m][n]
|
||||||
|
end
|
||||||
|
|
||||||
|
strs = %w[10 0001 111001 1 0]
|
||||||
|
m = 5
|
||||||
|
n = 3
|
||||||
|
puts find_max_form(strs, m, n)
|
||||||
|
# Output: 4
|
||||||
|
|
||||||
|
strs = %w[10 0 1]
|
||||||
|
m = 1
|
||||||
|
n = 1
|
||||||
|
puts find_max_form(strs, m, n)
|
||||||
|
# Output: 2
|
Loading…
Add table
Reference in a new issue