dynamic programming
from right bottom corner to top left
class Solution(object):
def findMaxForm(self, strs, m, n):
"""
:type strs: List[str]
:type m: int
:type n: int
:rtype: int
"""
dp=[[0 for _ in range(n+1)] for _ in range(m+1)]
for string in strs:
num_zeros=string.count('0')
num_ones=string.count('1')
for i in reversed(xrange(num_zeros,m+1)):
for j in reversed(xrange(num_ones,n+1)):
dp[i][j]=max(dp[i][j],dp[i-num_zeros][j-num_ones]+1)
return dp[m][n]
474. Ones and Zeroes
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- n the computer world, use restricted resource you have to...