NC133链表的奇偶重排
NC133链表的奇偶重排
- 1、题目描述:
- 2、题目链接:
https://www.nowcoder.com/practice/02bf49ea45cd486daa031614f9bd6fc3?tpId=117&&tqId=35488&rp=1&ru=/ta/job-code-high&qru=/ta/job-code-high/question-ranking
-3、 设计思想:
详细操作流程看下图:
-5、代码:
c++版本:
/**
* struct ListNode {
* int val;
* struct ListNode *next;
* };
*/
class Solution {
public:
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
* @param head ListNode类
* @return ListNode类
*/
ListNode* oddEvenList(ListNode* head) {
// write code here
if(head == NULL || head->next == NULL){
//如果头节点为空或者头节点的下一个节点为空直接返回
return head;
}
ListNode* odd = head;//奇链表头节点
ListNode* even = head->next;//偶链表头节点
ListNode* odd1 = odd;//进行奇链表的操作,最终成为奇链表尾节点
ListNode* even1 = even;//进行偶链表的操作,最终成为偶链表尾节点
while(odd1->next != NULL && even1->next != NULL){
/*
1->2->3->4->5
*/
odd1->next = even1->next;//奇链表的下一个节点应该等于偶数链表的下一个节点,如奇链表1下一位应该指向3
odd1 = odd1->next;//奇链表指向下一个节点
even1->next = odd1->next;//偶链表的下一个节点应该指向奇链表的下一个节点,如偶链表2下一位应该指向4
even1 = even1->next;//偶链表指向下一个节点
}
odd1->next = even;//最后将奇链表和偶链表拼接
return odd;
}
};
Java版本:
import java.util.
剩余60%内容,订阅专栏后可继续查看/也可单篇购买
Java岗位面试真题宝典 文章被收录于专栏
本面试宝典均来自校招面试题目大数据进行的整理

