1768. 交替合并字符串

1768. 交替合并字符串

给你两个字符串 word1word2 。请你从 word1 开始,通过交替添加字母来合并字符串。如果一个字符串比另一个字符串长,就将多出来的字母追加到合并后字符串的末尾。

返回 合并后的字符串

示例 1:

复制代码
输入:word1 = "abc", word2 = "pqr"
输出:"apbqcr"
解释:字符串合并情况如下所示:
word1:  a   b   c
word2:    p   q   r
合并后:  a p b q c r

示例 2:

复制代码
输入:word1 = "ab", word2 = "pqrs"
输出:"apbqrs"
解释:注意,word2 比 word1 长,"rs" 需要追加到合并后字符串的末尾。
word1:  a   b 
word2:    p   q   r   s
合并后:  a p b q   r   s

示例 3:

复制代码
输入:word1 = "abcd", word2 = "pq"
输出:"apbqcd"
解释:注意,word1 比 word2 长,"cd" 需要追加到合并后字符串的末尾。
word1:  a   b   c   d
word2:    p   q 
合并后:  a p b q c   d

提示:

  • 1 <= word1.length, word2.length <= 100
  • word1word2 由小写英文字母组成

题解:

java 复制代码
class Solution {
    public String mergeAlternately(String word1, String word2) {
        int minLen = Math.min(word1.length(), word2.length());
        StringBuilder sb = new StringBuilder("");
        for (int i = 0; i < minLen; i++) {
            sb.append(word1.charAt(i)).append(word2.charAt(i));
        }
       return sb.append(word1.substring(minLen)).append(word2.substring(minLen)).toString();
    }
}

笔记:

  1. int minLen = Math.min(word1.length(), word2.length());

    求两个字符串较短的那个,以它作为循环的限制;

  2. substring(); 截取字符串中介于两个指定下标之间的字符。

    用法:

    1. 两个参数:

    字符串.substring(参数1,参数2);

    参数1:字符串截取的起始下标,非负的整数

    如果此参数是0,则是从字符串的第一个字符开始截取

    参数2:截取结束位置的索引下标

    注意:截取的结果,不包括结束位置的字符

    示例:

    java 复制代码
    String str="abcdefghijklmn";
    String res=str.substring(2,6);
    System.out.println(res);
    结果res为:"cdef"
    1. 一个参数:
      字符串.substring(参数);
      参数:字符串截取的起始下标
      结果:从起始位置至字符串末尾的字符串
      示例:
    java 复制代码
    String str="abcdefghijklmn";
    String res=str.substring(3);
    System.out.println(res);
    结果res为:"defghijklmn"
  3. charAt(i) 函数 是获取字符串中i+1位置的字符

    eg :

    java 复制代码
    String str = "abc";
    //从字符串中取字符
    char ch = str.charAt(0); //第一个字符
    char ch2 = str.charAt(1);// 第二个字符
    结果res为: ch:a, ch2:b
  4. Java中append()方法

    1. Java中的StringBuffer/StringBuilder 类是动态字符串数组。
      StringBuilder :JDK5.0提供,运行效率快、线程不安全。(单)
      StringBuffer:JDK1.0提供,运行效率慢、线程安全。(多)

    概念:可在内存中创建可变的缓冲空间,存储频繁改变的字符串。

    优点:执行效率高于String。

    1. StringBuffer/StringBuilder 类包含append()方法,append()方法相当于"+",将指定的字符串追加到此字符序列。

    2. StringBuffer/StringBuilder.append()追加的字符串在同一个内存地址。

    eg:

    java 复制代码
    public class Test{
    public static void main(String args[]){
    StringBuffer sBuffer = new StringBuffer("aaa");
    	sBuffer.append("bbb");
    	sBuffer.append("ccc");
    	sBuffer.append("ddd");
    	System.out.println(sBuffer);  
    	}
    }
    结果res为: aaabbbcccddd
相关推荐
JJJJ_iii24 分钟前
【左程云算法09】栈的入门题目-最小栈
java·开发语言·数据结构·算法·时间复杂度
枫叶丹431 分钟前
【Qt开发】显示类控件(三)-> QProgressBar
开发语言·qt
三体世界33 分钟前
测试用例全解析:从入门到精通(1)
linux·c语言·c++·python·功能测试·测试用例·测试覆盖率
Python私教36 分钟前
Django全栈班v1.04 Python基础语法 20250912 下午
后端·python·django
Bear on Toilet1 小时前
继承类模板:函数未在模板定义上下文中声明,只能通过实例化上下文中参数相关的查找找到
开发语言·javascript·c++·算法·继承
xchenhao1 小时前
Scikit-Learn 对糖尿病数据集(回归任务)进行全面分析
python·机器学习·回归·数据集·scikit-learn·特征·svm
xchenhao1 小时前
Scikit-learn 对加州房价数据集(回归任务)进行全面分析
python·决策树·机器学习·回归·数据集·scikit-learn·knn
这里有鱼汤1 小时前
发现一个高性能回测框架,Python + Rust,比 backtrader 快 250 倍?小团队必备!
后端·python
☼←安于亥时→❦1 小时前
数据分析之Pandas入门小结
python·pandas
码猿宝宝1 小时前
浏览器中javascript时间线,从加载到执行
开发语言·javascript·ecmascript