474. Ones and Zeroes

T: O(len*m*n)

S: O(mn)

้€™้กŒๅฐฑๅƒๆ˜ฏๆœ‰ๅ…ฉๅ€‹ๅฎน้‡็š„่ƒŒๅŒ…, ๆ‰€ไปฅ็ตๅˆ 01่ƒŒๅŒ…็ฒพ็ฐกๅพŒ็š„ๅฏซๆณ•, ็”จ 2D ๅŽป่กจ็คบๅ…ฉๅ€‹่ƒŒๅŒ…

```java
class Solution {
    public int findMaxForm(String[] strs, int m, int n) {
        int[][] dp = new int[m+1][n+1];
        for (String s : strs) {
            int zeros = 0;
            int ones = 0;
            for (char c : s.toCharArray()) {
                if (c == '0') {
                    zeros++;
                } else {
                    ones++;
                }
            }

            for (int i = m; i >= zeros; i--) {
                for (int j = n; j >= ones; j--) {
                    dp[i][j] = Math.max(dp[i][j], dp[i - zeros][j - ones]+1); // ๅ–้€™ๅ€‹ str ๆˆ–ไธๅ–
                }
            }
        }
        return dp[m][n];
    }
}
```

Last updated