算法练习小技巧之有序集合--套路详细解析带例题(leetcode)

前言:

        本文详细讲解Python中的有序集合SortedList和C++中的有序集合multiset的用法,配合leetcode的例题来展示实际的用处。(本人水平不够,还无法讲解有序集合的实现方法,只会用)

        觉得有帮助或者写的不错可以点个赞,后面也有几道我找出来的题目可以用这个方法快速解决的

        (感觉有点水)

目录

有序集合用法讲解:

C++:

Python:

例题一:

题目描述和解题思路:

代码(C++):

代码(Python):

例题二:

题目描述和解题思路:

代码(Python):

一些可以用有序集合解的题目:


有序集合用法讲解:

(有序集合提供了有序性,但不够高效,可以简化代码,但慎用,比如例题二C++用就会超时)

C++:

        std::multiset 是来自 #include <set> 头文件

        可以高效的插入,删除,查找元素,插入进入的元素可以自动排序(升序排列),允许重复的元素

#include <iostream>
#include <set>

int main() {
    std::multiset<int> A;
    A.insert(4);
    A.insert(1);
    A.insert(3);
    A.insert(2);

    for (auto& a : A) {
        std::cout << a << " "; //输出1 2 3 4
    }
}

Python:

        SortedList 类是由 sortedcontainers 库提供的     

        注意这里的sortedcontainers 库是第三方库,使用的时候需要下载,在codeforces,atcoder等平台无法使用,但在leetcode里面可以使用

下载方法,在命令行输入: pip install sortedcontainers

 如图:

        

from sortedcontainers import SortedList

def main():
    A = SortedList(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值