C语言 | Leetcode C语言题解之第148题排序链表

题目:

题解:

struct ListNode* merge(struct ListNode* head1, struct ListNode* head2) {struct ListNode* dummyHead = malloc(sizeof(struct ListNode));dummyHead->val = 0;struct ListNode *temp = dummyHead, *temp1 = head1, *temp2 = head2;while (temp1 != NULL && temp2 != NULL) {if (temp1->val <= temp2->val) {temp->next = temp1;temp1 = temp1->next;} else {temp->next = temp2;temp2 = temp2->next;}temp = temp->next;}if (temp1 != NULL) {temp->next = temp1;} else if (temp2 != NULL) {temp->next = temp2;}return dummyHead->next;
}struct ListNode* sortList(struct ListNode* head) {if (head == NULL) {return head;}int length = 0;struct ListNode* node = head;while (node != NULL) {length++;node = node->next;}struct ListNode* dummyHead = malloc(sizeof(struct ListNode));dummyHead->next = head;for (int subLength = 1; subLength < length; subLength <<= 1) {struct ListNode *prev = dummyHead, *curr = dummyHead->next;while (curr != NULL) {struct ListNode* head1 = curr;for (int i = 1; i < subLength && curr->next != NULL; i++) {curr = curr->next;}struct ListNode* head2 = curr->next;curr->next = NULL;curr = head2;for (int i = 1; i < subLength && curr != NULL && curr->next != NULL;i++) {curr = curr->next;}struct ListNode* next = NULL;if (curr != NULL) {next = curr->next;curr->next = NULL;}struct ListNode* merged = merge(head1, head2);prev->next = merged;while (prev->next != NULL) {prev = prev->next;}curr = next;}}return dummyHead->next;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/852501.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

推流工具OBS的下载使用

一、下载安装 OBS&#xff0c;windows版本官网下载地址 二、推流步骤 安装好之后&#xff0c;打开软件 1、右下角&#xff0c;打开设置 2、输入推流地址&#xff0c;一般为rtmp格式开头的推流地址 输入完成后&#xff0c;应用并确定关闭窗口 3、“来源”里面新建媒体源、新…

Git分支打包的详细教程

以下是关于Git分支打包的详细教程&#xff0c;包括在本地和远程仓库中打包分支的步骤和常用命令。 在本地仓库中打包分支&#xff1a; a. 首先&#xff0c;确保你正在所需的分支上工作。使用 git branch 命令可以查看当前分支。 b. 执行命令 git archive 来打包分支。语法如下&…

《别让“想太多”挡了你的骑行路,对比一下更丝滑》

在探索骑行的世界时&#xff0c;我们往往会被一些先入为主的想法所束缚。本文将带你对比骑行与其他运动和生活方式&#xff0c;揭示那些阻碍你爱上骑行的认知误区。 一、年龄不是界限&#xff1a;骑行与跑步的比较与跑步相比&#xff0c;骑行同样适合所有年龄段&#xff0c;但它…

从“数据孤岛”、Data Fabric(数据编织)谈逻辑数据平台

提到逻辑数据平台&#xff0c;其核心在于“逻辑”&#xff0c;与之相对的便是“物理”。在过去&#xff0c;为了更好地利用和管理数据&#xff0c;我们通常会选择搭建数据仓库和数据湖&#xff0c;将所有数据物理集中起来。但随着数据量、用数需求和用数人员的持续激增&#xf…

单链表经典算法题 1

前言 学习了单链表&#xff0c;我们就做一些题来巩固一下。还有就是解题方法不唯一&#xff0c;我就只讲述为自己的方法。 目录 前言 1.移除链表元素 思路 代码 2.反转链表 思路 代码 3.链表的中间节点 思路 代码 总结 1.移除链表元素 思路 我们创建一个新的表…

docker-compose安装freeradius

freeradius docker 安装记录 docker安装freeradius #拉取镜像 docker pull freeradius/freeradius-server:latest #启动Freeradius容器 docker run -d --name freeradius-server -p 1812-1813:1812-1813/udp freeradius/freeradius-server #查看容器是否正常启动 docker ps -…

自学Java到找工作,最强学习路线,2024年最新版

本人是2024届的毕业生&#xff0c;自学Java的路上&#xff0c;也踩了不少的坑&#xff0c;希望在这里给小伙伴一些帮助&#xff0c;避免无效学习&#xff0c;一起进大厂&#xff01; ✔学习顺序&#xff1a; Java基础 ➡ Java进阶 ➡ Java并发 ➡ 数据结构 ➡ MySQL ➡ JavaW…

Shell中( ),(( ))的区别

在Shell编程中&#xff0c;() 和 (( )) 是两种常见的操作符&#xff0c;它们在不同的上下文中起到不同的作用。理解这两者的区别及其应用场景&#xff0c;有助于编写更加高效和灵活的Shell脚本。本文将详细介绍 () 和 (( )) 的功能及其使用方法。 1. 子Shell (()) 括号 () 用于…

接口幂等性问题

接口幂等性问题 描述 接口幂等性是软件开发时常见的问题&#xff0c;其目的是要求确保当同一个接口被重复调用时其状态不会发生变化 示例 当前一个支付页面&#xff0c;不管用户在同一时间内点击多少次支付按钮&#xff0c;最终接口也只会生成一个支付订单&#xff0c;这就…

AWS 网络

Here is a more detailed explanation of AWS networking in Chinese: VPC&#xff08;虚拟私有云&#xff09; VPC 是一个专门为您的 AWS 账户分配的虚拟网络。您可以将 VPC 视为云端的一个虚拟数据中心。在创建 VPC 时&#xff0c;您可以指定以下内容&#xff1a; IP 地址…

长连接的钟表程序

实验要求 实现1个钟表程序&#xff08;服务&#xff09;&#xff0c;多个用户可以从该程序获得时间并在本地显示&#xff0c;用户也可以修改时间。 &#xff08;1&#xff09;用户程序可以在计算机上运行&#xff0c;也可以在手机上运行&#xff1b; &#xff08;2&#xff…

Java 18 的一些主要新特性

以下是 Java 18 的一些主要新特性&#xff1a; 简单 Web 服务器&#xff08;JEP 408&#xff09;&#xff1a; Java 18 引入了一个简单的 Web 服务器&#xff0c;旨在帮助开发者更方便地测试和原型化。在命令行中使用 jwebserver 命令即可启动这个 Web 服务器。主要用于快速测试…

程序员如何挖掘项目开发出工具?(4)

如何利用最小的MVP&#xff08;最小可行产品&#xff09;模型找到第一个用户&#xff1f; 对许多人来说&#xff0c;找到第一个用户可能是整个过程中最具挑战性的部分&#xff0c;但在我看来&#xff0c;这其实是最简单的。 下面分享几个小技巧&#xff0c;如果你还是找不到第…

使用Kube-Bench对Kubernetes进行安全检测

使用Kube-Bench对Kubernetes进行安全检测 1. 工具介绍 Kube-Bench是一个开源的Go语言工具&#xff0c;用于自动化检查Kubernetes集群是否符合CIS Kubernetes基准。这些基准包括一系列关于Kubernetes配置和部署安全性的建议和最佳实践。 Kube-Bench执行了一系列针对Kubernete…

【Android】Android系统性学习——Android系统架构

前言 部分内容参考《Android进阶解密》 – 刘望舒 1. Android版本 官方链接&#xff1a;https://developer.android.com/studio/releases/platforms 里面有各个版本的官方文档&#xff0c;有些新功能的用法在这里面。 现在做安卓11&#xff0c;有时候需要向下兼容 2. AOSP …

【Python】在运行中使用warnings.filterwarnings,可以忽略测试中遇到的问题

在 Python 中&#xff0c;warnings 是一个内置模块&#xff0c;用于发出有关程序执行的警告信息&#xff0c;这些警告信息通常是关于程序行为的潜在问题。 不过&#xff0c;这些问题通常不是致命的错误&#xff0c;只不过是展示我们代码中潜在的问题&#xff0c;或不推荐的做法…

软件架构搞好了,还用担心代码可读性差?

目录 一、架构的概念及由来 二、小系统也需要架构思想 三、实现架构的思路 一、架构的概念及由来 嵌入式软件架构是指在嵌入式系统中用于组织和管理软件组件的结构和设计。嵌入式软件架构的出现是为了解决嵌入式系统中软件复杂度和系统要求不断增加的挑战。以下是嵌入式软件架…

【STM32进阶笔记】GPIO端口

前段时间由于其他原因&#xff0c;专栏暂停更新了较长一段时间&#xff0c;现在恢复更新&#xff0c;争取继续为大家创造有价值的内容&#xff0c;期待大家的订阅关注&#xff0c;欢迎互相学习交流。 在STM32速成笔记系列专栏中其实已经对GPIO的一些必要知识进行了介绍&#xf…

GPT4O给Qwen2生成的高考作文打分56分,从“小白”进阶技术大神的开发者基于国产GPU推理模型效果可还行?

OpenI启智社区上线的【芯动开源】首场活动-天数智芯挑战专场即将迎来最后一周的冲刺阶段&#xff0c;自2024年5月27日上线以来&#xff0c;这期间&#xff0c;我们见证了天数智芯通用GPU加速卡在适配AI模型方面的无限可能与开发者们开源精神的璀璨光辉。 在短短的两周时间里&a…

代码随想录算法训练营第二十三天|669. 修剪二叉搜索树、 108.将有序数组转换为二叉搜索树、 538.把二叉搜索树转换为累加树

669. 修剪二叉搜索树 题目链接&#xff1a;669. 修剪二叉搜索树 文档讲解&#xff1a;代码随想录 状态&#xff1a;还可以 思路&#xff1a; 如果节点的值在[low, high]之间&#xff0c;则递归修剪它的左子树和右子树。 节点值小于low&#xff1a;如果节点的值小于low&#xff…