第四天_双指针【算法入门】

简介: 第四天_双指针【算法入门】

344. 反转字符串

344. 反转字符串
编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。
不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。
示例 1:
输入:s = ["h","e","l","l","o"]
输出:["o","l","l","e","h"]
示例 2:
输入:s = ["H","a","n","n","a","h"]
输出:["h","a","n","n","a","H"]
提示:
1 <= s.length <= 105
s[i] 都是 ASCII 码表中的可打印字符

题解

思路
左右指针
左右指针分别从头和尾开始遍历数组,交换元素直到左指针大于右指针
class Solution {
    public void reverseString(char[] s) {
        int left=0;
        int rigth=s.length-1;
        char ch;
        while(left<=rigth){
            ch=s[left];
            s[left]=s[rigth];
            s[rigth]=ch;
            left++;
            rigth--;
        }
    }
}



557. 反转字符串中的单词 III

557. 反转字符串中的单词 III
给定一个字符串,你需要反转字符串中每个单词的字符顺序,同时仍保留空格和单词的初始顺序。
示例:
输入:"Let's take LeetCode contest"
输出:"s'teL ekat edoCteeL tsetnoc"
提示:
在字符串中,每个单词由单个空格分隔,并且字符串中不会有任何额外的空格。

题解

思路
取出每个单词进行翻转
空格表示单词结束
 思路
 快慢指针
 fast指针来判断空格,直到char[]数组最后
 当读取到空格时,就翻转[slow,fast)
 slow改为fast+1
 最后一个单词要单独处理
class Solution {
    public String reverseWords(String s) {
        Solution solution=new Solution();
        char[] chs=s.toCharArray();
        int slow=0;
        int fast=1;
        while(fast<chs.length){
            if(chs[fast]==' '){
                solution.reverseString(chs,slow,fast);
                slow=fast+1;
            }else if(fast==chs.length-1){
                solution.reverseString(chs,slow,fast+1);
            }
            fast++;
        }
        String reverseString=new String(chs);
        return reverseString;
    }
    public void reverseString(char[] s,int begin,int end) {
        int left=begin;
        int rigth=end-1;
        char ch;
        while(left<=rigth){
            ch=s[left];
            s[left]=s[rigth];
            s[rigth]=ch;
            left++;
            rigth--;
        }
    }
}

相关文章
|
12天前
|
机器学习/深度学习 人工智能 算法
深度学习入门:理解神经网络与反向传播算法
【9月更文挑战第20天】本文将深入浅出地介绍深度学习中的基石—神经网络,以及背后的魔法—反向传播算法。我们将通过直观的例子和简单的数学公式,带你领略这一技术的魅力。无论你是编程新手,还是有一定基础的开发者,这篇文章都将为你打开深度学习的大门,让你对神经网络的工作原理有一个清晰的认识。
|
29天前
|
算法 索引 容器
双指针算法详解
本文介绍了双指针算法及其应用。双指针算法是在数组或字符串中常用的高效技术,通过维护两个指针遍历数据结构以解决特定问题。根据指针移动方向,可分为同向双指针、相向双指针和快慢指针。同向双指针如移动零和复写零问题;快慢指针如快乐数问题;相向双指针如盛水最多的容器、有效三角形数量及多数之和等问题。通过合理运用双指针技巧,可简化代码并提高效率。
33 4
双指针算法详解
|
2月前
|
机器学习/深度学习 人工智能 算法
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
本文全面介绍了人工智能(AI)的基础知识、操作教程、算法实现及其在实际项目中的应用。首先,从AI的概念出发,解释了AI如何使机器具备学习、思考、决策和交流的能力,并列举了日常生活中的常见应用场景,如手机助手、推荐系统、自动驾驶等。接着,详细介绍了AI在提高效率、增强用户体验、促进技术创新和解决复杂问题等方面的显著作用,同时展望了AI的未来发展趋势,包括自我学习能力的提升、人机协作的增强、伦理法规的完善以及行业垂直化应用的拓展等...
157 3
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
|
2月前
|
存储 安全 编译器
C++入门 | auto关键字、范围for、指针空值nullptr
C++入门 | auto关键字、范围for、指针空值nullptr
51 4
|
2月前
|
Go 计算机视觉
Go从入门到放弃之指针
Go从入门到放弃之指针
|
3月前
|
机器学习/深度学习 数据采集 人工智能
机器学习算法入门与实践
【7月更文挑战第22天】机器学习算法入门与实践是一个既充满挑战又极具吸引力的过程。通过掌握基础知识、理解常见算法、注重数据预处理和模型选择、持续学习新技术和参与实践项目,你可以逐步提高自己的机器学习技能,并在实际应用中取得优异的成绩。记住,机器学习是一个不断迭代和改进的过程,保持好奇心和耐心,你将在这个领域走得更远。
|
3月前
|
消息中间件 存储 算法
实战算法的基础入门(2)
实战算法的基础入门
|
2月前
|
算法 容器
【算法】双指针
【算法】双指针
|
3月前
|
算法 Java
实战算法的基础入门(3)
实战算法的基础入门
|
2月前
|
存储 算法
【C算法】编程初学者入门训练140道(1~20)
【C算法】编程初学者入门训练140道(1~20)
下一篇
无影云桌面