zoukankan      html  css  js  c++  java
  • 86. 分隔链表

    给定一个链表和一个特定值 x,对链表进行分隔,使得所有小于 x 的节点都在大于或等于 x 的节点之前。
    你应当保留两个分区中每个节点的初始相对位置。
    示例:
    输入: head = 1->4->3->2->5->2, x = 3
    输出: 1->2->2->4->3->5
     
    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/partition-list
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
     
     
     
    新建两个节点
     
     
     
     
     
     
     
     
     
     1 class Solution {
     2 public:
     3     ListNode* partition(ListNode* head, int x) {
     4         ListNode less_head(0);//临时头节点,接收小于 x 的节点
     5         ListNode more_head(0);
     6         ListNode *less_ptr = &less_head;
     7         ListNode *more_ptr = &more_head;
     8         
     9         while (head) {
    10             if (head->val < x) {//向后移动,并且指向新节点
    11                 less_ptr->next = head;
    12                 less_ptr = head;
    13             } else {
    14                 more_ptr->next = head;
    15                 more_ptr = head;
    16             }
    17             head = head->next;
    18         }
    19         less_ptr->next = more_head.next;//连成一个新链表
    20         more_ptr->next = NULL;
    21         return less_head.next;
    22     }
    23 };
    测试
     1 int main(int argc, const char * argv[]) {
     2     ListNode a(1);
     3     ListNode b(4);
     4     ListNode c(3);
     5     ListNode d(2);
     6     ListNode e(5);
     7     ListNode f(2);
     8     a.next = &b;
     9     b.next = &c;
    10     c.next = &d;
    11     d.next = &e;
    12     e.next = &f;
    13     
    14     Solution solve;
    15     ListNode *head = solve.partition(&a, 3);
    16     while (head) {
    17         cout <<head->val<<endl;
    18         head = head->next;
    19     }
    20     
    21     return 0;
    22 }
    View Code

  • 相关阅读:
    洛谷 P2108 学英语
    洛谷 P1010 幂次方
    洛谷 P1101 单词方阵
    洛谷 P1217 [USACO1.5]回文质数 Prime Palindromes
    洛谷 P1553 数字反转(升级版)
    hdu_1348_Wall(凸包)
    hdu_1392_Surround the Trees(凸包)
    hdu_1115_Lifting the Stone(求多边形重心)
    Codeforces Round #354 (Div. 2)_Vasya and String(尺取法)
    hdu_1558_Segment set(并查集+计算几何)
  • 原文地址:https://www.cnblogs.com/i-8023-/p/11826065.html
Copyright © 2011-2022 走看看