【MT笔试题】

题目描述:

K 链表翻转是指把每K个相邻的结点看成一组进行翻转,如果剩余结点不足 K 个,则保持不变。假设给定链表 1 -> 2 -> 3 -> 4 -> 5 -> 6 -> 7 和一个数K,如果K的值为2,那么翻转后的链表是:2 -> 1 -> 4 -> 3 -> 6 -> 5 -> 7,如果K是3,那么翻转后的链表为:3 -> 2 -> 1 -> 6 -> 5 -> 4 -> 7.

解法: 先把链表按照K长度切割,把每段都翻转,除了最后一段,然后再链接起来。


  1. class k_reverse:
  2. def __init__(self):
  3. pass
  4. def __call__(self, link, k):
  5. return self.handle(link, k)
  6. @staticmethod
  7. def patition(link: SingleLink, k): # 切分
  8. cur = link.head
  9. head = cur
  10. lst = []
  11. i = 0
  12. maybe_tail = None
  13. while cur:
  14. i += 1
  15. if i != k: # 个数不够
  16. maybe_tail = cur
  17. cur = cur.next
  18. continue
  19. tmp = cur.next # 个数够了
  20. cur.next = None
  21. tail = cur
  22. cur = tmp
  23. temp = SingleLink()
  24. temp.head = head
  25. temp.tail = tail
  26. lst.append(temp)
  27. head = tmp
  28. i = 0
  29. temp = SingleLink()
  30. if head:
  31. temp.head = head
  32. if maybe_tail:
  33. temp.tail = maybe_tail
  34. if temp.head:
  35. lst.append(temp) # 最后一段不足k的头
  36. return lst
  37. @staticmethod
  38. def reverse(link: SingleLink): # 翻转
  39. left = link.head
  40. if left is None and left.next is None:
  41. return
  42. # 至少两个结点
  43. right = left.next
  44. while right:
  45. tmp = right.next
  46. right.next = left
  47. if left is link.head:
  48. left.next = None
  49. link.tail = left
  50. left = right
  51. right = tmp
  52. link.head = left
  53. def handle(self, link, k):
  54. part_lst = self.patition(link, k)
  55. for i in part_lst:
  56. if i == part_lst[-1]:
  57. break
  58. self.reverse(i)
  59. length = len(part_lst)
  60. if length: # 不为空
  61. i = 0
  62. while i < length-1:
  63. part_lst[i].tail.next = part_lst[i+1].head
  64. i += 1
  65. ln = SingleLink()
  66. ln.head = part_lst[0].head
  67. ln.tail = part_lst[-1].tail
  68. return ln

测试:

  1. instance = k_reverse()
  2. print("反转前: ", end="")
  3. p = ln.head
  4. while p:
  5. print(p.data, end=" ")
  6. p = p.next
  7. ln = instance(ln, 3)
  8. print()
  9. print("反转后: ", end="")
  10. p = ln.head
  11. while p:
  12. print(p.data, end=" ")
  13. p = p.next
  14. print()
  15. print("尾巴结点:", ln.tail.data)
  16. 反转前: 1 2 3 4 5 6 7 8
  17. 反转后: 3 2 1 6 5 4 7 8
  18. 尾巴结点: 8

如何把链表以k个结点为一组进行翻转的更多相关文章

  1. 单链表每k个节点为一组进行反转(最后不满k个时不反转)

    public class LinkReverse2 { public static Node mhead=null; public static Node mtail=null; public sta ...

  2. Reverse Nodes In K Group,将链表每k个元素为一组进行反转---特例Swap Nodes in Pairs,成对儿反转

    问题描述:1->2->3->4,假设k=2进行反转,得到2->1->4->3:k=3进行反转,得到3->2->1->4 算法思想:基本操作就是链表 ...

  3. 剑指offer四:链表中倒数第k个结点

    输入一个链表,输出该链表中倒数第K个结点 public class ListNode { int val; ListNode next = null; ListNode(int val) { this ...

  4. 剑指Offer 链表中倒数第k个结点

    题目描述 输入一个链表,输出该链表中倒数第k个结点.     思路: 法1:设置2个指针p,q.p先移动k次,然后pq同时后移,p到链表尾尾的时候,q指向倒数第k个节点. 注意://需要考虑k=0,以 ...

  5. 【编程题目】输入一个单向链表,输出该链表中倒数第 k 个结点

    第 13 题(链表):题目:输入一个单向链表,输出该链表中倒数第 k 个结点.链表的倒数第 0 个结点为链表的尾指针.链表结点定义如下: struct ListNode {int m_nKey;Lis ...

  6. 输出单向链表中倒数第k个结点

    描述 输入一个单向链表,输出该链表中倒数第k个结点,链表的倒数第0个结点为链表的尾指针. 链表结点定义如下: struct ListNode { int       m_nKey; ListNode* ...

  7. 找出链表中倒数第 k 个结点

    /* 题目:输入一个单向链表,输出该链表中倒数第 k 个结点.链表的倒数第 0 个结点为链表 的尾指针. 链表结点定义如下: struct node { int data; struct node * ...

  8. 链表中倒数第k个结点

    题目: 输入一个链表,输出该链表中倒数第k个结点. 思路: 因为是单向链表,如果使用最普通的遍历来解决的话会多出很多不必要的遍历.有一个比较好的解法,设置两个指针两个指针之间差k-1个位置,也就是当后 ...

  9. IT公司100题-13-求链表中倒数第k个结点

    问题描述: 输入一个单向链表,输出该链表中倒数第k个结点.链表倒数第0个节点为NULL. struct list_node { int data; list_node* next; }; 分析: 方法 ...

随机推荐

  1. 深入理解C# 委托(delegate)-戈多编程

    今天来谈谈委托,深入理解委托,本文来自各大神经验总结. 1.委托是什么? 委托类型的声明与方法签名相似. 它有一个返回值和任意数目任意类型的参数,是一种可用于封装命名方法或匿名方法的引用类型. 委托类 ...

  2. Jenkins设置BUILD NUMBER初始值

    由于服务器迁移,需要将之前的Jenkins构建项目一并迁移,为了区分构建编号,需要将所有项目的BUILDE NUMBER 初始值定义. 网上有一些资料是更新单个项目的,我们这项目几百个,所以只好自己研 ...

  3. linux 基本操作积累

    1 sed 命令,替换含有指定字符的一整行数据 sed -i 's/原字符串/替换后的字符串/g' ./文件名 (此命令会全局替换[整个文件内替换]原字符串) sed -i.bak 's/原字符串/替 ...

  4. Nmon监控结果分析

    一:CPU信息 SYS_SUMM图表: 1.折线图中蓝线为cpu占有率变化情况:粉线为磁盘IO的变化情况: 2.下面表各种左边的位磁盘的总体数据,包括如下几个: Avg tps during an i ...

  5. python学习(内置函数)

    1.id()返回对象的内存地址 a = 1 print id(a) print id(1) 2.int()用于将数据类型转换为整型 a = " b = 2 print int(a) + b ...

  6. [JZOJ100026]【NOIP2017提高A组模拟7.7】图

    Description 有一个n个点n条边的有向图,每条边为<i,f(i),w(i)>,意思是i指向f(i)的边权为w(i)的边,现在小A想知道,对于每个点的si和mi. si:由i出发经 ...

  7. 解决连接oracle报错 尝试加载Oracle客户端库时引发BadImageFomatException。如果在安装64位Oracle客户端组件的情况下以32位模式运行,将出现此问题的报错。

    最近遇到一个.NET连接Oracle的一个错误,其主要原因是换了一台电脑,在新电脑上运行以前的项目出现了的一个错误,工作环境为vs2017+Oracle 64位,win10系统 这个错误头疼了一天,找 ...

  8. java初始化与清理

    初始化与清理 欢迎转载,转载烦请注明出处,谢谢. https://www.cnblogs.com/sx-wuyj/p/11177257.html 1.用构造器确保初始化 java中通过提供构造器,可以 ...

  9. C#窗体练习:带历史信息的菜单

    在开发图纸管理软件时,要求在菜单上记录用户最近打开的档案或图纸,以方便下次使用.单击“文件”菜单下的“打开文件”子菜单,打开需要查阅的图纸.下次运行该软件时,上次打开的文件名记录到“文件”菜单的历史菜 ...

  10. 使用mongoose-paginate-v2查询缓慢问题

    场景 mongoose-paginate-v2 是一个mongoose上的分页插件,我也用过很多次了,但是最近在创建项目遇到了问题. 老代码中不使用分页插件进行查询,然后自己使用中间件进行分页 old ...