反转问题(字符串和链表)

最近刷代码随想录的双指针法时,遇到了不少的反转问题。

1、Leetcode 151 反转字符串中的单词(较难的字符串反转问题)

代码随想录说,如果直接使用split函数就变成了一道水题...

但我感觉输入的格式问题也是比较棘手的,我的思路是先找到字符串中第一个不为' '的字符,得到它的索引值,然后遍历到索引为s.length()-2的字符,遍历的字符如果不为' '或者为' '但是下一个字符不为' ',则append到新的StringBuilder中,最后把索引为s.length()-1的字符append到新的StringBuilder,因为索引为s.length()-1的字符的下一个字符会超出索引范围,所以需要单独处理,但是因为只有一个空格,不论最后一个字符是不是空格,split都可以成功的分割(总共的第一步是先去除多余的空格,有点类似移除元素的操作)

然后再使用倒序,即可获得一个新的StringBuilde,通过toString可以转化成目标字符串。

注意事项:

1、StringBuilder的toString()用法需要加括号

2、StringBuilder的append()用法可以是字符串也可以是字符(String没有append用法,只能拼接)

3、String的split()用法生成的是String[]类型(StringBuilder没有split用法)

java 复制代码
class Solution {
    public String reverseWords(String s) {
        StringBuilder temp = new StringBuilder();
        StringBuilder result = new StringBuilder();
        int n = s.length();
        int index = 0;
        for(int i=0;i<n;i++) {
            if(s.charAt(i) != ' ') {
                index = i;
                break;
            }
        }

        for(int i = index; i < n-1; i++) {      
            if( s.charAt(i) != ' ' || (s.charAt(i) == ' ' && s.charAt(i+1) != ' ')) {
                temp.append(s.charAt(i));
            }
        }
        temp.append(s.charAt(n-1));
        
        String[] sub = temp.toString().split(" ");
        for(int i=sub.length-1;i>0;i--) {
            result.append(sub[i]);
            result.append(" ");
        }
        result.append(sub[0]);
        return result.toString();
    }

}

下次使用代码思想录的双指针用法时,再添加上。

2、Leetcode 206 反转链表

该问题比较简单,之前也刷过该题目

但是长期不做链表的题目就容易疏忽一些注意事项

1、链表的head指针不能随便更改

2、在链表的尾部指向的是null

3、初始化用low指针指向null,fast指向head(因为反转必须有左右两个对象),第一次反转时,fast的左对象为null,右对象为原本的下一个节点,从指向右对象,变成了指向左对象,然后通过temp暂存fast原本的下一个节点的位置。(用fast和low命名是为了明确该方法用的也是双指针法,用cur和pre也是可以的)

java 复制代码
class Solution {
    public ListNode reverseList(ListNode head) {
        ListNode low = null;
        ListNode fast = head;
        ListNode temp = null;

        while(fast != null) {
            temp = fast.next;
            fast.next = low;
            low = fast;
            fast = temp;
        } 

        return low;
        
    }
}
相关推荐
Tingjct8 小时前
【初阶数据结构-二叉树】
c语言·开发语言·数据结构·算法
C雨后彩虹8 小时前
计算疫情扩散时间
java·数据结构·算法·华为·面试
飞机和胖和黄9 小时前
考研之王道C语言第三周
c语言·数据结构·考研
达文汐9 小时前
【困难】力扣算法题解析LeetCode332:重新安排行程
java·数据结构·经验分享·算法·leetcode·力扣
一匹电信狗9 小时前
【LeetCode_21】合并两个有序链表
c语言·开发语言·数据结构·c++·算法·leetcode·stl
执着2599 小时前
力扣hot100 - 234、回文链表
算法·leetcode·链表
Gorgous—l9 小时前
数据结构算法学习:LeetCode热题100-多维动态规划篇(不同路径、最小路径和、最长回文子串、最长公共子序列、编辑距离)
数据结构·学习·算法
一条大祥脚10 小时前
26.1.26 扫描线+数论|因子反演+子序列计数|树套树优化最短路
数据结构·算法
踩坑记录11 小时前
leetcode hot100 23. 合并 K 个升序链表 hard 分治 迭代
leetcode·链表
李老师讲编程12 小时前
C++信息学奥赛练习题-杨辉三角
数据结构·c++·算法·青少年编程·信息学奥赛