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。

相关推荐
bnmoel2 天前
数据结构深度剖析栈与队列:结构、边界实现与进出操作全解析
c语言·数据结构·算法··队列
汉克老师3 天前
GESP6级C++考试语法知识(十五、数据结构(一、认识栈 Stack))
c++··gesp6级·gesp六级·数组模拟栈
谙弆悕博士4 天前
【附C语言源码】C语言 栈结构 实现及其扩展操作
c语言·开发语言·数据结构·算法·链表·指针·
庞轩px8 天前
第二篇:内存——你的变量到底存在哪
内存···缓存命中率·变量生命周期·字符串常量
W.W.H.10 天前
嵌入式栈堆管理与内存分配详解
内存管理···rtos·heap·stack
浅念-16 天前
吃透栈:LeetCode 栈算法题全解析
数据结构·c++·算法·leetcode·职场和发展·
_小草鱼_1 个月前
【数据结构】栈和队列
数据结构·数组··队列
qeen871 个月前
【数据结构】栈及其C语言模拟实现
c语言·数据结构·学习·
旖-旎1 个月前
栈(验证栈序列)(5)
c++·算法·leetcode·力扣·
郝学胜-神的一滴1 个月前
二叉树后序遍历:从递归到非递归的优雅实现
数据结构·c++·程序人生·算法·