首页 > Java > java教程 > 交替合并字符串

交替合并字符串

Barbara Streisand
发布: 2025-01-06 16:18:42
原创
553 人浏览过

Merge Strings Alternately

嘿,程序员们!希望你一切都好。我很高兴能分享我的 LeetCode-75 系列解决方案,该系列涵盖 75 个基本问题,可帮助您准备编码面试。

在每篇文章中,我都会介绍我的解决方案以及我的方法的详细说明。请随时在评论中留下任何问题或改进建议。我期待与您的合作和讨论!快乐编码!

我在这里添加了问题的链接:Merge Strings Alternately

问题描述

给你两个字符串 word1 和 word2。通过以交替顺序添加字母来合并字符串,从 word1 开始。如果一个字符串比另一个字符串长,请将附加字母附加到合并字符串的末尾。

返回合并的字符串。

*示例 1:*

输入: word1 = "abc", word2 = "pqr"
输出:“apbqcr”
说明:合并后的字符串将按如下方式合并:
单词1:a b c
单词2:p q r
合并: a p b q c r

示例2:

输入: word1 = "ab", word2 = "pqrs"
输出:“apbqrs”
解释: 请注意,由于 word2 较长,因此“rs”会附加到末尾。
单词1:a b
单词2:p q r s
合并: a p b q r s

** 示例 3:**

输入: word1 = "abcd", word2 = "pq"
输出:“apbqcd”
解释: 请注意,由于 word1 较长,因此“cd”会附加到末尾。
单词1:a b c d
单词2:p q
合并: a p b q c d

解决方案

直觉

给定两个字符串,我们需要通过交替每个字符串中的字符来合并它们。如果两个字符串具有相同的长度,则解决方案很简单,但它们可以具有不同的长度。我们将使用指针迭代两个字符串,向结果添加字符,直到两个指针到达末尾。

方法

  1. 创建一个 StringBuilder 来存储两个字符串中的交替字符。
  2. 创建两个指针来跟踪每个字符串中的当前位置。
  3. 迭代两个字符串,直到两个指针都到达各自字符串的末尾。
  4. 如果字符串不为空,则将元素添加到 StringBuilder 并递增指针
  5. 返回 StringBuilder

复杂

  • 时间复杂度:
    时间复杂度为 O(n),其中 n 是较长字符串的长度,当我们迭代字符串时。

  • 空间复杂度:
    由于我们使用 StringBuilder 和一些变量,时间复杂度为 0(1)。

代码

  public String mergeAlternately (String word1, String word2) {
    // ? Create a StringBuilder to build the result string efficiently
    StringBuilder completeWord = new StringBuilder();

    // ? Initialize two pointers to traverse both strings
    int p1 = 0;
    int p2 = 0;

    // ? Iterate through both strings until both pointers reach the end of their resépectives strings
    while (p1 < word1.length() || p2 < word2.length()) {
      // ? Append the current character from words if the pointer is within bounds
      if (p1 < word1.length()) completeWord.append(word1.charAt(p1));
      if (p2 < word2.length()) completeWord.append(word2.charAt(p2));
      p1++;
      p2++;
    }
    // ? Convert the StringBuilder to a string and return it
    return completeWord.toString();
  }
登录后复制

以上是交替合并字符串的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:dev.to
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板