首页 后端开发 php教程 。将链表拆分为多个部分

。将链表拆分为多个部分

Sep 08, 2024 pm 12:31 PM

725。将链表拆分为多个部分

难度:中等

主题:链接列表

给定一个单链表的头和一个整数 k,将链表分割成 k 个连续的链表部分。

每个部分的长度应尽可能相等:任何两个部分的尺寸不应相差超过一倍。这可能会导致某些部分为空。

各部分应按照输入列表中出现的顺序排列,并且较早出现的部分的大小应始终大于或等于较晚出现的部分的大小。

返回由 k 个部分组成的数组

示例1:

. Split Linked List in Parts

  • 输入: head = [1,2,3], k = 5
  • 输出: [[1],[2],[3],[],[]]
  • 说明:
    • 第一个元素output[0]的output[0].val = 1,output[0].next = null。
    • 最后一个元素output[4]为null,但其作为ListNode的字符串表示形式是[]。

示例2:

. Split Linked List in Parts

  • 输入: head = [1,2,3,4,5,6,7,8,9,10], k = 3
  • 输出: [[1,2,3,4],[5,6,7],[8,9,10]]
  • 说明:
    • 输入已被分割成大小相差最多为 1 的连续部分,并且较早的部分比后面的部分尺寸更大。

约束:

  • 列表中的节点数量在 [0, 1000] 范围内。
  • 0
  • 1

提示:

  1. 如果列表中有 N 个节点,以及 k 个部分,则每个部分都有 N/k 个元素,除了前 N%k 部分有一个额外的元素。

解决方案:

关键的观察是每个部分的节点数不应相差超过 1。这意味着:

  1. 计算链表的长度。
  2. 确定每个部分的最小尺寸(part_size = length // k)。
  3. 将额外节点均匀分布在前几个部分(extra_nodes = length % k)。第一个 extra_nodes 部分应各有一个额外节点。

方法

  1. 计算长度:遍历链表,求节点总数。
  2. 确定各部分的大小
    • 每个部分应该至少有长度 // k 个节点。
    • 第一个长度 % k 的部分应该有一个额外的节点。
  3. 拆分列表:使用循环将链表拆分为 k 部分。对于每个部分:
    • 如果应该有额外的节点,则分配part_size + 1个节点。
    • 如果没有,则分配part_size节点。
  4. 空部分:如果列表短于k,则某些部分将为空(null)。

让我们用 PHP 实现这个解决方案:725。将链表拆分为多个部分

<?php
// Definition for singly-linked list.
class ListNode {
    public $val = 0;
    public $next = null;
    function __construct($val = 0, $next = null) {
        $this->val = $val;
        $this->next = $next;
    }
}
 /**
 * @param ListNode $head
 * @param Integer $k
 * @return ListNode[]
 */
function splitListToParts($head, $k) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

// Helper function to create a linked list from an array
function createLinkedList($arr) {
    $head = new ListNode($arr[0]);
    $current = $head;
    for ($i = 1; $i < count($arr); $i++) {
        $current->next = new ListNode($arr[$i]);
        $current = $current->next;
    }
    return $head;
}

// Helper function to print a linked list
function printList($head) {
    $result = [];
    while ($head !== null) {
        $result[] = $head->val;
        $head = $head->next;
    }
    return $result;
}

// Test case 1
$head = createLinkedList([1, 2, 3]);
$k = 5;
$result = splitListToParts($head, $k);
foreach ($result as $part) {
    print_r(printList($part));
}

// Test case 2
$head = createLinkedList([1, 2, 3, 4, 5, 6, 7, 8, 9, 10]);
$k = 3;
$result = splitListToParts($head, $k);
foreach ($result as $part) {
    print_r(printList($part));
}
?>

解释:

  1. 计算长度:我们首先遍历链表求其长度。

  2. 确定零件:

    • 我们将part_size计算为长度// k,这给出了每个部分应具有的最小尺寸。
    • 我们将 extra_nodes 计算为长度 % k,它给出了应该有一个额外节点的部分的数量。
  3. 拆分列表:我们循环遍历 k 个部分并拆分列表:

    • 对于每个部分,如果应该有额外的节点,则分配part_size + 1个节点,否则只分配part_size。
    • 在每个部分的末尾,我们断开与列表其余部分的链接。
  4. 处理空部分:如果节点数少于 k,则剩余部分将为 null(空)。

测试用例

  • 示例1
   $head = [1,2,3]; $k = 5;
   Output: [[1],[2],[3],[],[]]
  • 示例2
   $head = [1,2,3,4,5,6,7,8,9,10]; $k = 3;
   Output: [[1,2,3,4],[5,6,7],[8,9,10]]

该解决方案有效地将链表拆分为 k 个部分,时间复杂度为 (O(n + k)),其中 n 是列表的长度。

联系链接

如果您发现本系列有帮助,请考虑在 GitHub 上给 存储库 一个星号或在您最喜欢的社交网络上分享该帖子?。您的支持对我来说意义重大!

如果您想要更多类似的有用内容,请随时关注我:

  • 领英
  • GitHub

以上是。将链表拆分为多个部分的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Laravel 教程
1604
29
PHP教程
1510
276
PHP变量范围解释了 PHP变量范围解释了 Jul 17, 2025 am 04:16 AM

PHP变量作用域常见问题及解决方法包括:1.函数内部无法访问全局变量,需使用global关键字或参数传入;2.静态变量用static声明,只初始化一次并在多次调用间保持值;3.超全局变量如$_GET、$_POST可在任何作用域直接使用,但需注意安全过滤;4.匿名函数需通过use关键字引入父作用域变量,修改外部变量则需传递引用。掌握这些规则有助于避免错误并提升代码稳定性。

撰写PHP评论的提示 撰写PHP评论的提示 Jul 18, 2025 am 04:51 AM

写好PHP注释的关键在于明确目的与规范,注释应解释“为什么”而非“做了什么”,避免冗余或过于简单。1.使用统一格式,如docblock(/*/)用于类、方法说明,提升可读性与工具兼容性;2.强调逻辑背后的原因,如说明为何需手动输出JS跳转;3.在复杂代码前添加总览性说明,分步骤描述流程,帮助理解整体思路;4.合理使用TODO和FIXME标记待办事项与问题,便于后续追踪与协作。好的注释能降低沟通成本,提升代码维护效率。

在PHP中评论代码 在PHP中评论代码 Jul 18, 2025 am 04:57 AM

PHP注释代码常用方法有三种:1.单行注释用//或#屏蔽一行代码,推荐使用//;2.多行注释用/.../包裹代码块,不可嵌套但可跨行;3.组合技巧注释如用/if(){}/控制逻辑块,或配合编辑器快捷键提升效率,使用时需注意闭合符号和避免嵌套。

快速PHP安装教程 快速PHP安装教程 Jul 18, 2025 am 04:52 AM

ToinstallPHPquickly,useXAMPPonWindowsorHomebrewonmacOS.1.OnWindows,downloadandinstallXAMPP,selectcomponents,startApache,andplacefilesinhtdocs.2.Alternatively,manuallyinstallPHPfromphp.netandsetupaserverlikeApache.3.OnmacOS,installHomebrew,thenrun'bre

学习PHP:初学者指南 学习PHP:初学者指南 Jul 18, 2025 am 04:54 AM

易于效率,启动启动tingupalocalserverenverenvirestoolslikexamppandacodeeditorlikevscode.1)installxamppforapache,mysql,andphp.2)uscodeeditorforsyntaxssupport.3)

PHP调用AI智能语音助手 PHP语音交互系统搭建 PHP调用AI智能语音助手 PHP语音交互系统搭建 Jul 25, 2025 pm 08:45 PM

用户语音输入通过前端JavaScript的MediaRecorderAPI捕获并发送至PHP后端;2.PHP将音频保存为临时文件后调用STTAPI(如Google或百度语音识别)转换为文本;3.PHP将文本发送至AI服务(如OpenAIGPT)获取智能回复;4.PHP再调用TTSAPI(如百度或Google语音合成)将回复转为语音文件;5.PHP将语音文件流式返回前端播放,完成交互。整个流程由PHP主导数据流转与错误处理,确保各环节无缝衔接。

如何用PHP搭建社交分享功能 PHP分享接口集成实战 如何用PHP搭建社交分享功能 PHP分享接口集成实战 Jul 25, 2025 pm 08:51 PM

在PHP中搭建社交分享功能的核心方法是通过动态生成符合各平台要求的分享链接。1.首先获取当前页面或指定的URL及文章信息;2.使用urlencode对参数进行编码;3.根据各平台协议拼接生成分享链接;4.在前端展示链接供用户点击分享;5.动态生成页面OG标签优化分享内容展示;6.务必对用户输入进行转义以防止XSS攻击。该方法无需复杂认证,维护成本低,适用于大多数内容分享需求。

如何用PHP结合AI实现文本纠错 PHP语法检测与优化 如何用PHP结合AI实现文本纠错 PHP语法检测与优化 Jul 25, 2025 pm 08:57 PM

要实现PHP结合AI进行文本纠错与语法优化,需按以下步骤操作:1.选择适合的AI模型或API,如百度、腾讯API或开源NLP库;2.通过PHP的curl或Guzzle调用API并处理返回结果;3.在应用中展示纠错信息并允许用户选择是否采纳;4.使用php-l和PHP_CodeSniffer进行语法检测与代码优化;5.持续收集反馈并更新模型或规则以提升效果。选择AIAPI时应重点评估准确率、响应速度、价格及对PHP的支持。代码优化应遵循PSR规范、合理使用缓存、避免循环查询、定期审查代码,并借助X

See all articles