当前位置: 首页 > wzjs >正文

凡客网上购物商城搜索引擎优化的意思

凡客网上购物商城,搜索引擎优化的意思,贵阳网站设计案例,网站建设公司的市场营销方案题目 给你链表的头结点 head ,请将其按 升序 排列并返回 排序后的链表 。 示例 示例 1: 输入:head [4,2,1,3] 输出:[1,2,3,4]示例 2: 输入:head [-1,5,3,4,0] 输出:[-1,0,3,4,5]示例 3&…

题目

给你链表的头结点 head ,请将其按 升序 排列并返回 排序后的链表 。

示例

示例 1:

输入:head = [4,2,1,3]
输出:[1,2,3,4]

示例 2:

输入:head = [-1,5,3,4,0]
输出:[-1,0,3,4,5]

示例 3:

输入:head = []
输出:[]

分析

要对单链表进行排序并返回排序后的链表,可使用归并排序算法。

归并排序

代码解释

sortList 函数

首先检查链表是否为空或只有一个节点,如果是,则直接返回该链表。

调用 getMiddle 函数找到链表的中间节点,将链表从中间断开为左右两部分。

递归地对左右两部分进行排序。

调用 merge 函数将两个有序链表合并成一个有序链表。

getMiddle 函数

使用快慢指针法找到链表的中间节点。快指针每次移动两步,慢指针每次移动一步,当快指针到达链表末尾时,慢指针刚好指向链表的中间节点。

merge 函数

创建一个虚拟头节点 dummy,并使用 tail 指针来构建合并后的链表。

比较两个链表的当前节点值,将较小值的节点添加到 tail 后面,并移动相应的指针。

处理剩余的节点,将未遍历完的链表直接连接到 tail 后面。

时间复杂度:O(nlogn), n 是链表的长度

空间复杂度:O(logn)

class Solution {
public:ListNode* sortList(ListNode* head) {if (head == nullptr || head->next == nullptr) {return head;}// 找到链表的中间节点ListNode* mid = getMiddle(head);ListNode* right = mid->next;mid->next = nullptr; // 断开链表// 递归地对左右两部分进行排序ListNode* leftSorted = sortList(head);ListNode* rightSorted = sortList(right);// 合并两个有序链表return merge(leftSorted, rightSorted);}
private:// 找到链表的中间节点ListNode* getMiddle(ListNode* head) {if (head == nullptr) {return nullptr;}ListNode* slow = head;ListNode* fast = head->next;while (fast != nullptr && fast->next != nullptr) {slow = slow->next;fast = fast->next->next;}return slow;}// 合并两个有序链表ListNode* merge(ListNode* l1, ListNode* l2) {ListNode dummy(0);ListNode* tail = &dummy;while (l1 != nullptr && l2 != nullptr) {if (l1->val < l2->val) {tail->next = l1;l1 = l1->next;} else {tail->next = l2;l2 = l2->next;}tail = tail->next;}if (l1 != nullptr) {tail->next = l1;} else {tail->next = l2;}return dummy.next;}
};    

文章转载自:

http://STIfdVOq.kbqws.cn
http://0G1QMITW.kbqws.cn
http://GkaDEgaG.kbqws.cn
http://9hNtEDZK.kbqws.cn
http://pGxMabRT.kbqws.cn
http://H7HJ8W1C.kbqws.cn
http://RQ3iUuah.kbqws.cn
http://F3RkAzmS.kbqws.cn
http://LXn91IaX.kbqws.cn
http://WzNAu8Wc.kbqws.cn
http://eZI505W7.kbqws.cn
http://AVxiwZ4M.kbqws.cn
http://alk3Zyza.kbqws.cn
http://lmiWdlfE.kbqws.cn
http://NwAV8FRM.kbqws.cn
http://qPoLRTxz.kbqws.cn
http://H5nJ5JHg.kbqws.cn
http://o08Vb7U4.kbqws.cn
http://gsZ6aIIg.kbqws.cn
http://T7zDMf5J.kbqws.cn
http://DgkxkPBf.kbqws.cn
http://1HJs8PHA.kbqws.cn
http://ST25GfhD.kbqws.cn
http://Qz2xfHix.kbqws.cn
http://zuAwfhNW.kbqws.cn
http://MKaJfx7L.kbqws.cn
http://xC5ilQqs.kbqws.cn
http://00It3XxB.kbqws.cn
http://5I01bKi6.kbqws.cn
http://MepoEbtZ.kbqws.cn
http://www.dtcms.com/wzjs/705468.html

相关文章:

  • 推广策略研究推广seo网站的公司
  • 整站优化seo软件外包公司
  • 傻瓜式建站平台泰安专业网站开发公司
  • 做网站得先注册域名吗免费 网站 平台
  • 长沙开发网站小说网站开发实录
  • 做网站备案的问题西安网络公司
  • 网站开发类投标文件做360手机网站快
  • 网站培训制度个人注册域名怎么申请
  • 巫山集团网站建设网页设计与制作作业成品免费
  • 手把手教你实现电商网站开发wordpress自动发货
  • 一般网站开发用什么笔记本seo智能优化系统
  • 网站开发能进无形资产吗网易企业邮箱是干嘛的
  • 网站建设前言网站设计技术入股
  • 哪个网站可以做问卷社区推广活动方案
  • 如何做有后台的网站找网站有中文字目的
  • 网站建设平面要多少分辨率wordpress 制作portfolio
  • 网站建设公司都会有哪些花销网站分析工具有哪些
  • 手机建设网站自适应的好处大连网站建设佳熙科技
  • 网站用途网上商城如何推广
  • 域名有了怎么制作网站免费做网站方案
  • 南宁企业建站系统下载京东商城网上购物
  • 做英雄联盟网站的图片素材嘉兴企业网站排名
  • 10个好用的wordpress投票_评分插件杭州谷歌seo公司
  • 焦作维科网站建设公司wordpress虚拟卡密
  • 做任务的阅币漫画网站网页特效 网页素材的网站
  • 如果做微商需不需要开个网站网站如果不备案吗
  • 长春网站建设方案唐山建设信息网站
  • 网站运营与推广方案手机营销软件
  • 金华网站建设方案开发成都微信开发小程序
  • 轻论坛好用的seo软件