明霞山资源网 Design By www.htccd.com
题目:
给定一个单链表的头指针 head, 以及两个整数 a 和 b,在单链表中反转 linked_list[a-b] 的结点,然后返回整个链表的头指针。
例如:
单链表[1000, 5, 12, 100, 45, ‘cecil', 999],
a = 4, b = 6,
返回的链表是[1000, 5, 12, 100, 999, ‘cecil', 45],也就是说,
a 和 b分别为索引值。如果a 和 b 超过了索引范围就返回错误。
代码:
我写的不够简洁,比较繁琐,但是能跑通,繁琐的原因在于我使用了 for 循环,对于 a == 0 的情况 for 循环无法识别。
def reverse_part_linked_list(head, a, b): # 反转部分链表结点,a, b分别为索引值 if head == 0: print "Empty linked list. No need to reverse." return head p = head length = 1 while p != 0: length += 1 p = p.next if length == 1: print "No need to reverse." return head if a < 0 or b > length-1 or a >= b: raise Exception("The given 'from' value and 'to' value is wrong.") p = head if a == 0: # 由于 for 循环中 xrange 的范围问题,我就分情况写了。 tail, head = p, p pre = 0 for _ in xrange(a, b+1): p = p.next head.next = pre pre = head head = p tail.next = p return head else: for _ in xrange(1, a): p = p.next front, tail, head = p, p, p p = p.next pre = 0 for _ in xrange(a+1, b+2): p = p.next head.next = pre pre = head head = p front.next = pre tail.next = p return head
分析:
核心依然是反转链表的指针问题,均是一遍循环,时间复杂度o(n),空间复杂度为若干个变量。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
明霞山资源网 Design By www.htccd.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
明霞山资源网 Design By www.htccd.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。