25. Reverse Nodes in k-Group
2021/11/15 11:10:09
本文主要是介绍25. Reverse Nodes in k-Group,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
SLinkedList<int> slist = new SLinkedList<int>(); slist.AppendRange(new[] { 1, 2, 3, 4, 5 }); Console.WriteLine("Input: " + slist.Print()); Console.WriteLine("k=2"); var rslt = slist.RotateRight(2); Console.WriteLine(rslt.Print());
/// <summary> /// 向右旋转链表 k 次 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="source"></param> /// <param name="k"></param> /// <returns></returns> public static SLinkedList<T> RotateRight<T>(this SLinkedList<T> source, int k) where T : IComparable<T> { if (source.Head == null || source.Head.Next == null || k == 0) { return source; } var len = source.Count; if (k % len == 0) { return source; } var tmp = new SLinkedList<T>(source); var head = tmp.Head; var tmp2 = new SLinkedList<T>(head); var newHead = tmp2.Head; var cur = newHead; while (cur.Next != null) { cur = cur.Next; } // 连接 cur.Next = head; cur = newHead; for (int i = len - k % len; i > 0; i--) { cur = cur.Next; } var res = new SLinkedList<T>(); for (int i = 0; i < len; i++) { res.Append(cur.Data); cur = cur.Next; } return res; }
这篇关于25. Reverse Nodes in k-Group的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-07-02springboot项目无法注册到nacos-icode9专业技术文章分享
- 2024-06-26结对编程到底难不难?答案在这里
- 2024-06-19《2023版Java工程师》课程升级公告
- 2024-06-15matplotlib作图不显示3D图,怎么办?
- 2024-06-1503-Loki 日志监控
- 2024-06-1504-让LLM理解知识 -Prompt
- 2024-06-05做软件测试需要懂代码吗?
- 2024-06-0514-ShardingSphere的分布式主键实现
- 2024-06-03为什么以及如何要进行架构设计权衡?
- 2024-05-31全网首发第二弹!软考2024年5月《软件设计师》真题+解析+答案!(11-20题)