当前位置: 代码迷 >> 综合 >> 【Leetcode 每日一题】649. Dota2 参议院(贪心)
  详细解决方案

【Leetcode 每日一题】649. Dota2 参议院(贪心)

热度:0   发布时间:2023-11-23 11:54:24.0

Leetcode 每日一题
题目链接: 649. Dota2 参议院
难度: 中等
解题思路: 最优的策略是前一个议员一定要禁止后一个最先发言的不同阵营的议员,这样才能保证对本阵营最优。以使得本阵营的越少的人被禁止。按照这个逻辑来完成就行了。
题解:

class Solution:def predictPartyVictory(self, senate: str) -> str:R = D = Trueflag = 0senate = [item for item in senate]while R and D:  # 只要有一个确定胜利退出R = D = Falsefor i in range(len(senate)):if senate[i] == 'R':if flag < 0:    # 此时它前面是有D的所以他是被禁止权力的senate[i] = 'N' # 标记为没权利else:R = Trueflag += 1elif senate[i] == 'D':if flag > 0:    # 此时它前面是有R的所以他是被禁止权力的senate[i] = 'N' # 标记为没权利else:D = Trueflag -= 1# print(R, D)if R:return "Radiant"if D:return "Dire"