LeetCode 24. 两两交换链表中的节点

题目链接

24. 两两交换链表中的节点

思路

核心思路是通过「虚拟头节点 + 节点删除 / 插入」的方式实现两两交换:

  1. 先创建一个虚拟头节点(dummy) 指向原链表头节点,避免处理头节点交换的特殊情况;
  2. 遍历链表时,每次定位到需要交换的两个相邻节点(记为 first、second);
  3. 先将 first 节点从原位置 “删除”,再将 first 节点插入到 second 节点的后面;
  4. 移动遍历指针,重复上述过程直到所有两两节点交换完成。

图解过程

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

1.初始化链表

ListNode dummy = new ListNode(-1, head);

ListNode cur = dummy;

重复上面过程

代码

importjava.io.BufferedReader;importjava.io.IOException;importjava.io.InputStreamReader;publicclass 两两交换链表中的节点 {staticclassListNode{int val;ListNode next;ListNode(int val){this.val = val;}ListNode(int val,ListNode next){this.val = val;this.next = next;}}staticBufferedReader in =newBufferedReader(newInputStreamReader(System.in));publicstaticvoidmain(String[] args)throwsIOException{String[] s = in.readLine().split(" ");ListNode head =newListNode(Integer.parseInt(s[0]));ListNode cur = head;// 1 2 3for(int i =1; i < s.length; i++){ListNode node =newListNode(Integer.parseInt(s[i])); cur.next = node; cur = cur.next;}ListNode newHead =swapPairs(head); cur = newHead;while(cur !=null){System.out.print(cur.val +" "); cur = cur.next;}}// 思路 删除第一个节点 并记录 然后放到第二个节点后面publicstaticListNodeswapPairs(ListNode head){if(head ==null|| head.next ==null){return head;}ListNode dummy =newListNode(-1, head);ListNode cur = dummy;while(cur.next !=null&& cur.next.next !=null){// 记录第一个节点ListNode first = cur.next;// 删除第一个节点 cur.next = cur.next.next;// 记录后面的节点ListNode second = cur.next.next; cur.next.next = first; first.next = second; cur = cur.next.next;}return dummy.next;}}

Read more

Flutter for OpenHarmony: Flutter 三方库 week_of_year 为鸿蒙应用提供精准的年度周数统计与业务分析支持(日历计算专家)

Flutter for OpenHarmony: Flutter 三方库 week_of_year 为鸿蒙应用提供精准的年度周数统计与业务分析支持(日历计算专家)

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net 前言 在进行 OpenHarmony 的办公自动化(OA)、排班管理或财务统计应用开发时,我们经常需要处理“周”的概念。 1. 周报提交:今天是今年的第几周? 2. 生产计划:第 15 周需要完成哪些鸿蒙节点的部署? 3. 数据报表:按周对鸿蒙设备的运行状态进行汇总。 虽然 Dart 的 DateTime 类非常强大,但它并没有原生支持“获取当前是第几周”。week_of_year 软件包通过对 DateTime 对象的精简扩展,让你能一行代码获取 ISO-8601 标准的周数。 一、周数计算逻辑模型 符合国际标准(ISO-8601)的周数计算,通常将包含一年中第一个周四的那一周定为第 1 周。 DateTime

By Ne0inhk
Flutter for OpenHarmony:markdown 纯 Dart 解析引擎(将文本转化为结构化 HTML/UI) 深度解析与鸿蒙适配指南

Flutter for OpenHarmony:markdown 纯 Dart 解析引擎(将文本转化为结构化 HTML/UI) 深度解析与鸿蒙适配指南

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net 前言 Markdown 因其简洁的语法,已成为开发者编写文档、博客、评论的首选格式。 在 Flutter 应用中,我们经常需要渲染 Markdown 内容(如帮助文档、Terms of Service、用户评论)。 markdown 是 Dart 官方维护的标准库,它负责将 Markdown 文本解析为抽象语法树(AST)或直接转换为 HTML。它是 flutter_markdown 等高层 UI 库的基石。 对于 OpenHarmony 开发者,如果你需要自己实现一个轻量级的 Markdown 渲染器,或者需要对 Markdown 文本进行预处理(如提取目录、过滤敏感词),直接使用

By Ne0inhk
Flutter for OpenHarmony:darq 让 Dart 拥有 C# LINQ 般的超能力(集合查询与变换神器) 深度解析与鸿蒙适配指南

Flutter for OpenHarmony:darq 让 Dart 拥有 C# LINQ 般的超能力(集合查询与变换神器) 深度解析与鸿蒙适配指南

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter for OpenHarmony:darq 让 Dart 拥有 C# LINQ 般的超能力(集合查询与变换神器) 深度解析与鸿蒙适配指南 前言 如果你是从 .NET/C# 转到 Dart/Flutter 开发的,你一定无比怀念 LINQ (Language Integrated Query)。 虽然 Dart 的 Iterable 提供了 map, where, reduce 等基础方法,但在处理复杂数据集合(如多重排序、连接 Join、分组 GroupBy、去重)时,原生 API 依然显得力不从心,

By Ne0inhk
Flutter 三方库 dns_client 的鸿蒙化适配指南 - 告别 DNS 劫持、探索 DNS-over-HTTPS (DoH) 技术、构建安全的鸿蒙网络请求环境

Flutter 三方库 dns_client 的鸿蒙化适配指南 - 告别 DNS 劫持、探索 DNS-over-HTTPS (DoH) 技术、构建安全的鸿蒙网络请求环境

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 dns_client 的鸿蒙化适配指南 - 告别 DNS 劫持、探索 DNS-over-HTTPS (DoH) 技术、构建安全的鸿蒙网络请求环境 在移动互联网时代,DNS 劫持和隐私泄露是网络请求中的“两大顽疾”。当你为鸿蒙系统开发高性能的金融、通讯或工具类应用时,如何确保你的域名解析既快又安全?今天我们来聊聊 dns_client 这个能让你的 Flutter 应用直接对话全球顶级 DNS 服务的利器。 前言 传统的 DNS 查询基于 UDP,既不加密也容易被篡改。而 dns_client 通过 DNS-over-HTTPS (DoH) 技术,将 DNS 查询请求封装在加密的

By Ne0inhk