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

池州网站网站建设铁岭免费网站建设

池州网站网站建设,铁岭免费网站建设,天峨县建设局网站,做简历的网站有哪些前言: 最近在leetcode刷题时用到了重叠对pairwise,这里就讲解一下迭代工具函数pairwise,既介绍给大家,同时也提醒一下自己,这个pairwise其实在刷题中十分有用,相信能帮助到你。 参考官方讲解:itertools --- 为高效循…

前言:

最近在leetcode刷题时用到了重叠对pairwise,这里就讲解一下迭代工具函数pairwise,既介绍给大家,同时也提醒一下自己,这个pairwise其实在刷题中十分有用,相信能帮助到你。

参考官方讲解:itertools --- 为高效循环创建迭代器的函数 — Python 3.13.1 文档

1.1基本用法:

itertools.pairwise(iterable)返回从iterable中获取的连续的重叠对,(同时这个只有Python3.1才支持),同时输出的迭代器二元组的数量将比输入的数量少一个;如果输入的可迭代对象少于两个值,那么它将为空:

举个例子:pairwise('ABCDEFGH')  ——> AB  BC CD DE EF FG GH

                  pairwise('A') ——> None

所以在运用时要保证适用对象不少于两个元素,否者就没有意义。

同时pairwise 的对象时可迭代的,那么许多迭代器都可以用在里面,比用用map封装一个迭代器,同时还可以实现map所指定的函数,这个衍生用法在后面会详细讲解到

1.2内在逻辑:

在了解了用法之后,我们也可以更深入的了解pairwise的实现逻辑:

def pairwise(iterable):iterator = iter(iterable)a = next(iterator, None)for b in iterator:yield a, ba = b

说明:

iter函数:用iter(object)来生成迭代器,object是指一个支持迭代的对象,第二个参数是每次元素要调用的函数,如果只是想将元素转化为可迭代的,那么可以不传入第二个参数

next函数:用next( iterable , None )从迭代中获取下一个元素,如果迭代器中没有更多的元素他会引发None,当然这个None也可以是其他响应。同时和for函数类似,只不过,next更适合于更细粒度的控制,或者处理复杂的数据结构。值得一提的是next访问同一个对象是会从上一次访问的末尾开始如果是第一次则从开头开始访问。

it = iter(['A','B','C'])
print(next(it, '没有更多元素')) # 输出 A
print(next(it, '没有更多元素')) # 输出 B
print(next(it, '没有更多元素')) # 输出 C
print(next(it, '没有更多元素')) # 输出 '没有更多元素'

yield函数 :把yield理解成return,区别在于前者返回一个可迭代的生成器对象,你可以使用for循环或者用next()方法遍历生成器来提取结果,return则是直接返回所有结果,程序终止不在运行,并且销毁局部变量。

def fun():x = 2y = 6while x < y:yield xx += 1example = fun()
# example 是一个可迭代的生成器<generator object fun at 0x0000025C491D1C00>
next(example,'No result!')
next(example,'No result!')
next(example,'No result!')
next(example,'No result!')
next(example,'No result!')
next(example,'No result!')
next(example,'No result!')
#结果:
#2
#3
#4
#5
#Nor result !

1.3运用:

运用1:

传送门:

题型属于分组循环,分组循环可以用for或者while 实现,题解参考灵神: 

class Solution:def longestContinuousSubstring(self, s: str) -> int:ans = cnt = 1for x, y in pairwise(map(ord, s)):cnt = cnt + 1 if x + 1 == y else 1ans = max(ans, cnt)return ans

用一个map创建一个可迭代的对象,并且每一个对象都用ord处理,这样写不仅更加简洁

而如果每一次都比较一下Unicode码显然不是那么方便,当然也可以做

class Solution:def longestContinuousSubstring(self, s: str) -> int:i,n = 0, len(s)ans = 0while i < n:start = ii += 1while i < n and ord(s[i])-1 == ord(s[i-1]):i += 1ans = max(ans, i - start)return ans 

运用2: 

传送门:

这也是分组循环里面典型的例题:,利用冒泡的思想直接排序

class Solution:def canSortArray(self, nums: List[int]) -> bool:n = len(nums)i = 0while i < n:start = iones = nums[i].bit_count()i += 1while i < n and nums[i].bit_count() == ones:i += 1nums[start:i] = sorted(nums[start:i])return all(x <= y for x, y in pairwise(nums))

今天的介绍到此为止,谢谢大家的观看!

http://www.yayakq.cn/news/485518/

相关文章:

  • 用div做网站代码口碑营销为什么越来越重要
  • 自己怎么建网站卖东西wordpress文章列表缩略图
  • 如何解决网站只收录首页的一些办法网络营销的几种模式
  • 网站建设实训分析总结织梦网站变成手机站
  • 淘宝优惠券返利网站怎么做上海发布
  • 网站源码下载后怎么用网站建设怎么让网站收录
  • 邢台专业做网站的地方wordpress用户系统
  • 怎么用dw做静态网站修改wordpress的语言
  • seo网站建设步骤python基础教程免费
  • 免费网站建设联系电话建设银行网站 购买外汇
  • 做文学网站编辑的前景电子商务网站建设需要的语言及特点6
  • 外包网站济南做网站公司电话
  • 哪个网站做娱乐建设银行怎么加入信用网站
  • 珠海网站建设运营公司中国移动璧山网站建设
  • 网站搭建步骤广告创意设计竞赛
  • 个人网站如何在百度上做推广wordpress 后台底部修改
  • 网站界面大小网站做好怎么推广
  • 北京的电商平台网站有哪些黄岛开发区做网站的公司
  • 紫色 网站做网站年薪百万
  • 在线代理访问网站的网址如何做网页制作
  • 网站设计网站开发优化wordpress模版标签
  • 国外做测评的网站有哪些台州建设银行官方网站
  • 网站怎么做mip技术wordpress 课程管理
  • 专做女鞋的网站网站建设通讯设备中企动力
  • 江门网站优化经验交易所源码
  • 海口网站建设在线著名网站建设公司
  • 学校网站建设方案策划书如何制作网站图片
  • 电脑版网站建设企业建设网站管理制度
  • 湘潭网站建设速来磐石网络公司名称大全二字
  • 宝安网站建设推广站外推广免费网站