题解 | #链表的奇偶重排#

链表的奇偶重排

https://www.nowcoder.com/practice/02bf49ea45cd486daa031614f9bd6fc3

/** * 13: 链表的奇偶重排 *给定一个单链表,请设定一个函数,将链表的奇数位节点和偶数位节点分别放在一起,重排后输出。 * 注意是节点的编号而非节点的数值。 * 解题思路:创建俩个额外的链表,分别用来存放奇数偶数,遍历完成后将俩个链表合并到一起 */

public ListNode oddEvenList (ListNode head) {
    if (head == null){
        return null;
    }
    if (head.next == null){
        return  head;
    }
    ListNode p=head;
    int n=1;//用来判断是奇数偶数
   ListNode Js=new ListNode(-1);//奇数链表
   ListNode Os=new ListNode(-1);//偶数链表
    ListNode cur = Js;
    ListNode cur1 = Os;
   while (p!=null){
       if (n%2!=0){//如果是奇数的话,用尾插法插到奇数链表后
           ListNode listNode = new ListNode(p.val);
           cur.next = listNode;
           cur=listNode;
       } else{//如果是偶数的话,用尾插法插到偶数链表后
           ListNode listNode = new ListNode(p.val);
           cur1.next = listNode;
           cur1=listNode;
       }
       p=p.next;
       n++;
   }
   p=Js;
   //将俩个链表合并
   while (p.next!=null){
       p=p.next;
   }
   p.next=Os.next;
   return Js.next;
}

全部评论

相关推荐

看到这个内容真是闹麻了。。。。。。现在有了AI以后很多人面试都会作弊吗? 那对老老实实面试的人岂不是不公平....
程序员牛肉:公平那是对小孩子讲的童话故事,成年人的世界只有能不能接受失败的后果。 你要是能接受面试作弊被发现之后多家公司联合永久拉黑的后果,你就搞。
点赞 评论 收藏
分享
ohs的小木屋:比不少实习待遇高了
点赞 评论 收藏
分享
牛客38347925...:9,2学生暑期实习失利开始投小厂,给这群人整自信了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务