信创国产化替换如何推动企业自主创新与市场竞争力提升
581
2022-10-09
474. Ones and Zeroes
In the computer world, use restricted resource you have to generate maximum benefit is what we always want to pursue.
For now, suppose you are a dominator of m 0s and n 1s respectively. On the other hand, there is an array with strings consisting of only 0s and 1s.
Now your task is to find the maximum number of strings that you can form with given m 0s and n 1s. Each 0 and 1 can be used at most once.
Note: The given numbers of 0s and 1s will both not exceed 100 The size of given string array won’t exceed 600. Example 1:
Input: Array = {"10", "0001", "111001", "1", "0"}, m = 5, n = 3Output: 4Explanation: This are totally 4 strings can be formed by the using of 5 0s and 3 1s, which are “10,”0001”,”1”,”0”
Example 2:
Input: Array = {"10", "0", "1"}, m = 1, n = 1Output: 2Explanation: You could form "10", but then you'd have nothing left. Better form "0" and "1".
class Solution { public int findMaxForm(String[] strs, int m, int n) { int[][] dp = new int[m + 1][n + 1]; for(String s : strs) { int[] num = findNumberOfZeroOne(s); for(int i = m; i >= num[0]; i--) { for(int j = n; j >= num[1]; j--) { dp[i][j] = Math.max(dp[i][j], 1 + dp[i - num[0]][j - num[1]]); } } } return dp[m][n]; } private int[] findNumberOfZeroOne(String s) { int[] num = new int[2]; for(int i = 0; i < s.length(); i++) { char c = s.charAt(i); if(c == '0') num[0]++; if(c == '1') num[1]++; } return
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~