C语言数据结构旋转链表的实现

2025-05-27 0 26

C语言数据结构旋转链表的实现

实例:

给出链表1->2->3->4->5->null和k=2

返回4->5->1->2->3->null

分析

感觉很直观,直接把分割点找出来就行,记得k可能大于len,要取模

代码:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45
/**

* Definition for singly-linked list.

* struct ListNode {

* int val;

* ListNode *next;

* ListNode(int x) : val(x), next(NULL) {}

* };

*/

class Solution {

public:

/**

* @param head: the list

* @param k: rotate to the right k places

* @return: the list after rotation

*/

ListNode *rotateRight(ListNode *head, int k) {

// write your code here

if(head==NULL)

return head;

int len = 0;

ListNode*temp = head;

while(temp)

{

len++;

temp = temp->next;

}

k%=len;

if(k==0)

return head;

k = len-k;

temp = head;

while(k>1)

{

temp = temp->next;

k--;

}

ListNode*newStart = temp->next;

temp->next = NULL;

temp = newStart;

while(temp->next)

temp = temp->next;

temp->next = head;

return newStart;

}

};

以上就是C语言数据结构旋转链表的实现,如有疑问请留言或者到本站社区交流讨论,本站关于数据结构的文章还有很多,希望大家搜索查阅,大家共同进步!

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 C语言数据结构旋转链表的实现 https://www.kuaiidc.com/72352.html

相关文章

发表评论
暂无评论