python的一些库

文章目录

  • collections
    • Counter
    • deque
    • defaultdict
    • OrderedDict

刷leetcode碰到很多可以直接用python本身提供的一些库和结构,感觉有必要汇总一下,之前列过一次数据结构,太基础还是不够用。
https://blog.csdn.net/wwang_123/article/details/134994224
随时更新一下吧,常看常新。

https://docs.python.org/zh-cn/3.13/library/datatypes.html

collections

Counter

方便、快速的计数;

类似于字典,如果某个项缺失,会返回0,而不是报错;

from collections import *#Counter
cnt = Counter()
wordList = ["a","b","c","c","a","a"]
for word in wordList:cnt[word] += 1
print(cnt)
# Counter({'a': 3, 'c': 2, 'b': 1})c=Counter("gallery")
print(c)
# Counter({'l': 2, 'g': 1, 'a': 1, 'e': 1, 'r': 1, 'y': 1})# 常用操作
# 统计所有的数目
print(sum(c.values()))
# 7# 列出所有唯一的元素
print(list(c))# 转换为set
print(set(c))
# ['g', 'a', 'l', 'e', 'r', 'y']# 转换为常规的dict
print(dict(c))
# {'a', 'e', 'g', 'l', 'r', 'y'}

deque

栈和队列的一种广义实现,支持两端插入和删除元素

append(x)
appendleft(x)
count(x) # 返回deque中元素等于x的个数
extend(iterable)
extendleft(iterable)
pop()
popleft()
remover(value)# 移除第一次出现的value,如果没找到,报错
reverse() # 反转deque的元素,并返回None
rotate(n) # 从右侧反转n步,如果n为负数,则从左侧反转,d.rotate(1)等于d.appendleft(d.pop());
from collections import dequed=deque("abc")
print(d)
# deque(['a', 'b', 'c'])d.append('j')
d.appendleft('f')
print(d)
# deque(['f', 'a', 'b', 'c', 'j'])d.pop()
d.popleft()
print(d)
# deque(['a', 'b', 'c'])

defaultdict

defaultdict是内置数据类型dict的一个子类,基本功能与dict一样,只是重写了一个方法__missing__(key)和增加了一个可写的对象变量default_factory

from collections import defaultdicts = [('yellow',1),('blue',2),('yellow',3),('blue',4),('red',5)]
d = defaultdict(list)
for k,v in s:d[k].append(v)
print(d)
# defaultdict(<class 'list'>, {'yellow': [1, 3], 'blue': [2, 4], 'red': [5]})# 设置default_factory为int,使得defaultdict可以用于计数
s="testdefaultdefault"
d=defaultdict(int)
for k in s:d[k]+=1
print(d)
# defaultdict(<class 'int'>, {'t': 4, 'e': 3, 's': 1, 'd': 2, 'f': 2, 'a': 2, 'u': 2, 'l': 2})# 将default_factory设置为set,使得defaultdict可以建立一个关于set的词典
s = [('red', 1), ('blue', 2), ('red', 3), ('blue', 4), ('red', 1), ('blue', 4)]
d = defaultdict(set)
for k,v in s:d[k].add(v)
print(d)
# defaultdict(<class 'set'>, {'red': {1, 3}, 'blue': {2, 4}})

OrderedDict

类似于正常的词典,只是记住了元素插入的顺序,当在有序的词典上迭代时,返回的元素就是它们第一次添加的顺序。

from collections import OrderedDict
d = {"banana":3,"apple":2,"pear":1,"orange":4}
print(OrderedDict(sorted(d.items(),key=lambda t: t[0])))
# OrderedDict([('apple', 2), ('banana', 3), ('orange', 4), ('pear', 1)])print(OrderedDict(sorted(d.items(),key=lambda t: t[1])))
# OrderedDict([('pear', 1), ('apple', 2), ('banana', 3), ('orange', 4)])print(OrderedDict(sorted(d.items(),key = lambda t:len(t[0]))))
# OrderedDict([('pear', 1), ('apple', 2), ('banana', 3), ('orange', 4)])

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/7120.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vue 基础语法

【1】模板语法 &#xff08;1&#xff09;差值表达式 {{}}是 Vue.js 中的文本插值表达式。 它用于在模板中输出数据或表达式的值。当数据或表达式的值发生变化时&#xff0c;插值表达式会自动更新。 补充&#xff1a;三目运算符 它的基本语法是 Condition ? A : B&#xff0…

STM32CubeMX打开中文乱码

在STM32CubeMX生成的文件中&#xff0c;用Keil5打开中&#xff0c;在其中写入中文注释之后&#xff0c;再次用STM32CubeMX打开生成之后&#xff0c;部分中文就会出现乱码问题&#xff0c;在Keil5中的编码是使用utf-8的编码格式&#xff0c;而在windows系统下&#xff0c;STM32C…

一起了解开源自定义表单的优势表现

随着社会的进步和科技的发展&#xff0c;越来越多的中小企业希望采用更为先进的软件平台&#xff0c;助力企业实现高效率的流程化管理。低代码技术平台、开源自定义表单已经慢慢走入大众视野&#xff0c;成为一款灵活、高效的数字化转型工具。流辰信息专注于低代码技术平台的研…

鸿蒙内核源码分析(原子操作篇) | 谁在为原子操作保驾护航

基本概念 在支持多任务的操作系统中&#xff0c;修改一块内存区域的数据需要“读取-修改-写入”三个步骤。然而同一内存区域的数据可能同时被多个任务访问&#xff0c;如果在修改数据的过程中被其他任务打断&#xff0c;就会造成该操作的执行结果无法预知。 使用开关中断的方…

更适合宝妈和上班族的兼职,每天2小时收入250+的微头条项目

许多人通过撰写微头条赚取收入&#xff0c;但这通常需要自己寻找素材&#xff0c;然后逐字逐句地进行改编创作&#xff0c;整个过程既繁琐又低效。 然而&#xff0c;如今全球范围内的AI工具正如雨后春笋般涌现。百度推出了文心一言&#xff0c;阿里巴巴推出了AI工具通义千问&a…

【必看】ESP32-C3 IDF+VsCode 开发环境搭建(ubuntu 22.04)

详细可阅读官方文档&#x1f603;&#xff08;release/v4.4&#xff09;&#xff1a;点此进入 一、 安装准备&#x1f6e0;︎ 1.1 工具链安装 编译 ESP-IDF 需要以下软件包 sudo apt-get install git wget flex bison gperf python3 python3-pip python3-setuptools cmake n…

【信息系统项目管理师知识点速记】质量管理:控制质量

控制质量是为了评估绩效,确保项目输出完整、正确且满足客户期望,而监督和记录质量管理活动执行结果的过程。控制质量过程需要在整个项目期间开展,其目的是测量产品或服务的完整性、合规性和适用性,以确保项目达到主要干系人的质量要求。 12.5.1 输入 项目管理计划 质量管理…

JavaSE_抽象类(抽象类概念、语法、、特性、作用)

前言 在上一节中&#xff0c;我们讲解了JAVA中的继承&#xff0c;在本节讲解java中抽象类与接口&#xff0c;这个在程序设计中是非常重要的。 一、什么是抽象类 1.1 抽象类概念 基本概念&#xff1a; 在面向对象的概念中&#xff0c;所有的对象都是通过类来描绘的&#xff0…

动态规划——背包问题(01,完全,多重)

一、01背包问题 1.题目描述 有 N 件物品和一个容量是 V 的背包。每件物品只能使用一次。第 i 件物品的体积是 vi&#xff0c;价值是 wi。 求解将哪些物品装入背包&#xff0c;可使这些物品的总体积不超过背包容量&#xff0c;且总价值最大。输出最大价值。 01背包问题特点&…

客户管理软件排行榜:对比18款CRM

本文将对比18个客户管理软件&#xff1a;纷享销客、Zoho CRM、Salesforce、HubSpot CRM、Pipedrive、Freshsales、Microsoft Dynamics 365 CRM、Insightly CRM、Nimble CRM、Apptivo CRM、SugarCRM、白码CRM、简信CRM、销帮帮CRM、Teamface企典CRM、神州云动CRM、悟空CRM、八百…

由于找不到msvcp120.dll,无法继续执行代码的5种解决方法

在操作计算机的过程中&#xff0c;您或许会遇到这样一种情形&#xff1a;当试图启动某个软件应用程序时&#xff0c;系统突然弹出一个错误提示框&#xff0c;明确指出“找不到msvcp120.dll”&#xff0c;它会导致程序无法正常启动或运行。为了解决这个问题&#xff0c;我总结了…

详细分析Java中的@Service注解

目录 1. 基本知识2. Demo2.1 传统形式2.2 注解形式 3. 总结 1. 基本知识 Service 是 Spring Framework 中的一个注解&#xff0c;用于标识一个类为服务层组件 服务层&#xff08;Service Layer&#xff09;&#xff1a; 服务层是应用程序的一个层次结构&#xff0c;位于控制层…

OpenNJet:云原生技术中的创新者与实践者

目录 引言OpenNJet介绍OpenNJet优势1. 性能无损动态配置2. 灵活的CoPilot框架3. 支持HTTP/34. 支持国密5. 企业级应用6. 高效安全 OpenNJet 编译与安装环境准备编译环境配置配置yum源yum 安装软件包创建符号连接修改 ld.so.conf 配置 编译代码 部署 WEB SERVER配置OpenNJet部署…

深入探索JDK:Java开发工具包的奥秘

深入探索JDK&#xff1a;Java开发工具包的奥秘 随着信息技术的飞速发展&#xff0c;Java作为一种广泛使用的编程语言&#xff0c;在各个领域都发挥着重要作用。而JDK&#xff08;Java Development Kit&#xff0c;Java开发工具包&#xff09;作为Java编程的基础&#xff0c;其…

k8s的架构组成

一 k8s的概述 1.1 概述 k8s是一个轻便的和可扩展的开源平台&#xff0c;用于管理容器化应用和服务&#xff0c;通过k8s能够进行应用的自动化部署和扩缩容。 k8s可以创建多个容器&#xff0c;每个容器运行一个应用实例&#xff0c;然后通过内置的负载均衡策略&#xff0c;实现…

Docker安装gitlab后连接内置pgsql修改用户信息

Docker安装gitlab后连接内置pgsql修改用户信息 进入gitlab容器 docker exec -it gitlab /bin/bash 进入postgresql su - gitlab-psql 连接pgsql psql -h /var/opt/gitlab/postgresql -d gitlabhq_production 命令行直接执行SQL语句 psql -h /var/opt/gitlab/postgresql…

HCIP-Datacom-ARST必选题库_BGP【道题】

1.关于summary automatic命令和BGP聚合的描述,错误的是? 该命令用于实现自动聚合,其优先级高于手动聚合 配置该命令后,BGP将按自然网段聚合路由 该命令用来使能对本地引入的路由进行自动聚合 配置该命令后,BGP只向对等体发送聚合后的路由 1.关于summary automatic命令和BGP聚…

Vue入门到关门之Vue3项目创建

一、vue3介绍 1、为什么要学习vue3&#xff1f; vue3的变化&#xff1a; 首先vue3完全兼容vue2&#xff0c;但是vue3不建议用vue2的写法&#xff1b;其次&#xff0c;vue3拥抱TypeScript&#xff0c;之前vue2使用的JavaScript&#xff0c;ts完全兼容js 最后之前学的vue2 是…

面试经典150题——找出字符串中第一个匹配项的下标

面试经典150题 day23 题目来源我的题解方法一 库函数方法二 自定义indexOf函数方法三 KMP算法 题目来源 力扣每日一题&#xff1b;题序&#xff1a;28 我的题解 方法一 库函数 直接使用indexOf函数。 时间复杂度&#xff1a;O(n) 空间复杂度&#xff1a;O(1) public int str…

(数据分析方法)长期趋势分析

目录 一、定义 二、目的 三、方法 1、移动平均法 (1)、简单移动平均法 (2)、加权移动平均法 (3)、指数平滑法 2、最小二乘法 3、线性回归 1、数据预处理 2、观察数据分布建立假设模型 3、定义损失函数 4、批量梯度下降 5、优化 4、LSTM 时序分析 5、特征工程 一…