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

算法笔试-编程练习-好题-07

本次分享的不是一道具体的题目,而是关于python的一个输出技巧。

在笔试中我们常会遇到被要求将结果 list 输出为由空格分隔的形式,例如[1, 2, 3, 4]输出为 ’1 2 3 4‘。

在这样的过程中我们有可能第一反应按照下面的方式处理结果:

ans = ""
for r in result:
    ans += str(r) + " "
print(ans[:-1])

如果不熟悉python的底层的话,上面的程序看起来就是O(n)的时间复杂度。但是由于python的字符串类型的变量底层上是不可变的,因此每一次的+=,都需要经历:1)计算两边的字符串的长度,2)然后开辟一块的新的空间,3)将原来的ans复制进入新空间,4)将 += 右侧的内容追加到新空间中ans 的尾部。其实际计算过程的复杂度远高于O(n)

因此这样的输出方法,在面对题目要求O(n)的时间复杂度的算法时就会导致我们的代码超时,即使我们的核心代码没问题。

因此在面对上述输出要求时,建议采用下面的输出方式:

print(' '.join(map(str, result))

' '.join函数,会在result的每个元素之间添加一个空格,上面的字符串构建时,会先计算最终字符串的长度,然后再开辟空间,因此只会经历1次的空间开辟过程,整体的时间复杂度符合O(n)


http://www.kler.cn/a/314946.html

相关文章:

  • BoltzGnu Boltztrap数据绘图脚本
  • 【Linux】shell脚本编程
  • Linux系统自动化sh脚本
  • 基于SMT32U575RIT单片机-中断练习
  • FastAPI vs Flask 专业对比与选择
  • Python递归(汉诺塔问题)
  • 《MmAP : Multi-Modal Alignment Prompt for Cross-Domain Multi-Task Learning》中文校对版
  • Homebrew安装与切换下载源
  • 单例模式(饿汉式-懒汉式)
  • leetcode:3232. 判断是否可以赢得数字游戏(python3解法)
  • FastDFS架构和原理
  • RabbitMQ:交换机详解(Fanout交换机、Direct交换机、Topic交换机)
  • Linux实用命令 df和du命令
  • 数据结构之‘栈’
  • 面向对象程序设计
  • VisionPro - 基础 - 模板匹配技术-Search/PMAlign/PatMax(6)-纹理屏蔽和重叠匹配
  • Redis面试真题总结(四)
  • 多模态交互才是人机交互的未来
  • MoFA: 迈向AIOS
  • 【QGIS入门实战精品教程】6.1:QGIS根据属性条件查询数据(SQL表达式)
  • 如何在GitHub上Clone项目:一步步指南
  • 暑假考研集训营游记
  • 李宏毅机器学习2023-HW13-Network Compression
  • 4.《DevOps》系列K8S部署CICD流水线之Helm部署Harbor私人镜像仓库
  • 机器学习中求解模型参数的方法
  • LabVIEW编程能力如何能突飞猛进