Leetcode 3781. Maximum Score After Binary Swaps

  • [Leetcode 3781. Maximum Score After Binary Swaps](#Leetcode 3781. Maximum Score After Binary Swaps)
    • [1. 解题思路](#1. 解题思路)
    • [2. 代码实现](#2. 代码实现)

1. 解题思路

这一题是Leetcode双周赛172的第三题,是一道medium难度的题目。

这一题的思路就是一个有序栈的思路,对于任意一个 1 1 1出现的位置,他能取到的最大值就是其前方所有出现过的元素的最大值,因此,我们只需要维持一个有序数组,其元素为前序所有元素的值,然后每次遇到一个 1 1 1的位置,就弹出当前数组中最大的值即可。

2. 代码实现

给出python代码实现如下:

python 复制代码
class Solution:
    def maximumScore(self, nums: List[int], s: str) -> int:
        cache = []
        ans = 0
        for num, ch in zip(nums, s):
            bisect.insort(cache, num)
            if ch == "1":
                ans += cache[-1]
                cache.pop()
        return ans

提交代码评测得到:耗时1575ms,占用内存33.30MB。

相关推荐
txzrxz19 小时前
数据结构有关的题目(栈,队列,set和map)
数据结构·c++·笔记·算法··队列
闻缺陷则喜何志丹3 天前
P10160 [DTCPC 2024] Ultra|普及+
数据结构·c++··洛谷
星火开发设计5 天前
C++ stack 全面解析与实战指南
java·数据结构·c++·学习·rpc··知识
无尽的罚坐人生13 天前
hot 100 42. 接雨水
数据结构·算法·leetcode·动态规划··双指针
漫随流水15 天前
leetcode算法(150.逆波兰表达式求值)
数据结构·算法·leetcode·
漫随流水15 天前
leetcode算法(1047.删除字符串中的所有相邻重复项)
算法·leetcode·
Q741_14715 天前
C++ 栈 模拟 力扣 946. 验证栈序列 每日一题 题解
c++·算法·leetcode·模拟·
长安er19 天前
LeetCode 20/155/394/739/84/42/单调栈核心原理与经典题型全解析
数据结构·算法·leetcode·动态规划·
Espresso Macchiato20 天前
Leetcode 3782. Last Remaining Integer After Alternating Deletion Operations
迭代·leetcode hard·leetcode双周赛172·leetcode 3782