把 row 跟 inverse(row) 視為一樣 然後去找max count
說是這樣說
我也很不會用
就全部硬做string來稿==
看答案好像有其他特別的方法
明天再來研究
先睡
def maxEqualRowsAfterFlips(self, matrix: List[List[int]]) -> int:
def flip(s):
tmp = []
for c in s:
if c == '0':
tmp.append('1')
else:
tmp.append('0')
return "".join(tmp)
mp = {}
for row in matrix:
mp["".join([str(i) for i in row])] += 1
ans = 0
for key, val in mp.items():
cur_cnt = val
if flip(key) in mp:
cur_cnt += mp[flip(key)]
ans = max(ans, cur_cnt)
return ans