当前位置: 首页 > news >正文

蓝桥杯算法之基础知识(2)——Python赛道

1.循环里面套用递归,当递归执行return时,只会退出当前递归层

2.不能一边遍历list 一边pop

解决办法:倒序遍历解决或者创建新的列表去存储

3.sqrt求出来的始终是小数形式,注意题目要求的结果有可能是整型

你直接sqrt就提交,那不直接相当于没做了,填空题很容易丢分。

4.python的递归是有深度限制的,默认是1000

你在尝试递归的时候可以试着试验范围内的大数,如果报深度超了 就自己设置深度sys.setrecursionlimit()

5.列表的两种格式

6.set集合在迭代的时候不能一边遍历一边赋值

-解决方法要不就是新加一个变量去代替要不就是将set变为list(set())

7.sys加快输入(这个很有用,一般对于那些限制短时间完成的,你使用这个前缀一般是比普通的数据读入快的)

在每次代码之前加入

import sys

input=sys.stdin.readline

》特殊情况

对于输入的数字。int() 和 split() 会忽略换行符,所以数字输入通常不用手动处理。

对于输入的字符串,sys.stdin.readline 返回的字符串末尾带换行符(\n),而 input() 会自动去掉。所以需要专门处理

8.二维矩阵赋值

a=[[for _ in range(n)] for _ in range(m)]-----由a=[0 for _ in range(m)]--->[0,0,0,0,0]推广而来

---[[xx],[xx],[xx]]

a=[[0]*N for i in range(0,N)]
#s=[[0]*N for i in range(0,N)]
# print(a)


for i in range(1,n+1):
rows = [0]
rows.extend(list(map(int,input().split())))
for j in range(1,m+1):
a[i][j]=rows[j]

9.input的各个输入窍门

input()---int(input())

n,m=map(int,input().split())

list=list(map(int,input().split()))

list[1:n+1]=list(map(int,input().split()))

*list[1:n+1]:表示列表 list 的第 1 个到第 n 个位置(不包括第 n+1 个位置)

10.list的小技巧(必看)

list的min,max,sum,count方法

》添加元素

方法功能添加方式示例
append添加单个元素到列表末尾将整个对象作为单个元素添加[1, 2, 3].append([4, 5])[1, 2, 3, [4, 5]]
extend添加可迭代对象的所有元素到列表末尾将可迭代对象的元素逐个添加[1, 2, 3].extend([4, 5])

insert(i, x):在索引 i 插入元素 x。

a = [1, 2, 3] 
a.insert(1, 5) 
print(a)  # [1, 5, 2, 3]

》删除元素

  • remove(x):删除第一个值为 x的元素,没找到会抛 ValueError

    a = [1, 2, 3, 2] a.remove(2) print(a) # [1, 3, 2]

  • pop([i]):删除并返回索引 i的元素,默认最后一个。

    a = [1, 2, 3] x = a.pop(1) print(x) # 2 print(a) # [1, 3]

  • clear():清空列表。

    a = [1, 2, 3] a.clear() print(a) # []

》查找元素

  • index(x[, start[, end]]):返回第一个 x 的索引,没找到抛 ValueError

    a = [1, 2, 3, 2] print(a.index(2)) # 1 print(a.index(2, 2)) # 3(从索引 2 开始找)

  • count(x):统计 x出现的次数。

    a = [1, 2, 2, 3] print(a.count(2)) # 2

》排序和翻转

  • sort(key=None, reverse=False):原地排序(前面讲过)。

    a = [3, 1, 2] a.sort() print(a) # [1, 2, 3]

  • reverse():反转列表。

    a = [1, 2, 3] a.reverse() print(a) # [3, 2, 1]

》复制

  • copy():返回列表的浅拷贝。

    a = [1, 2, 3] b = a.copy() b[0] = 4 print(a) # [1, 2, 3] print(b) # [4, 2, 3]

http://www.xdnf.cn/news/1352539.html

相关文章:

  • 【51单片机学习】直流电机驱动(PWM)、AD/DA、红外遥控(外部中断)
  • mmdetection:记录算法训练配置文件
  • A Large Scale Synthetic Graph Dataset Generation Framework的学习笔记
  • Mysql EXPLAIN详解:从底层原理到性能优化实战
  • 如何在Ubuntu中删除或修改已有的IP地址设置?
  • C语言---数据类型
  • PyTorch生成式人工智能——VQ-VAE详解与实现
  • TypeScript 的泛型(Generics)作用理解
  • Kafka 概念与概述
  • 在TencentOS3上部署OpenTenBase:从入门到实战的完整指南
  • 【Java学习笔记】18.反射与注解的应用
  • 遥感机器学习入门实战教程|Sklearn案例⑧:评估指标(metrics)全解析
  • tcpdump命令打印抓包信息
  • 【golang】ORM框架操作数据库
  • 2-5.Python 编码基础 - 键盘输入
  • STM32CubeIDE V1.9.0下载资源链接
  • 醋酸镨:催化剂领域的璀璨新星
  • LangChain4J-基础(整合Spring、RAG、MCP、向量数据库、提示词、流式输出)
  • 信贷模型域——信贷获客模型(获客模型)
  • 温度对直线导轨的性能有哪些影响?
  • 小白向:Obsidian(Markdown语法学习)快速入门完全指南:从零开始构建你的第二大脑(免费好用的笔记软件的知识管理系统)、黑曜石笔记
  • 数字经济、全球化与5G催生域名新价值的逻辑与实践路径
  • 快速掌握Java非线性数据结构:树(二叉树、平衡二叉树、多路平衡树)、堆、图【算法必备】
  • vue3 - 组件间的传值
  • 【小沐学GIS】基于Godot绘制三维数字地球Earth(Godot)
  • 计算机网络 TLS握手中三个随机数详解
  • 【Golang】有关垃圾收集器的笔记
  • 语义通信高斯信道仿真代码
  • GaussDB 数据库架构师修炼(十八) SQL引擎-计划管理-SQL PATCH
  • Base64编码、AES加密、RSA加密、MD5加密