「每日一题」反转字符串

createh54周前 (04-09)技术教程8

题目:

编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。

请注意不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。

解题(Java):

class Solution {
    public void reverseString(char[] s) {
        //双指针,左指针从0开始,右指针从数组结尾开始,左右指针对应的数字互换位置,然后同时向中间位置移动,直到左指针>=右指针
        int left = 0,right = s.length - 1;
        while(left < right){
            char temp = s[left];
            s[left] = s[right];
            s[right] = temp;
            left ++;
            right --;
        }
    }
}

思路解析:

使用双指针解题,分析题目可以得出:反转字符其实就是第一个和最后一个互换位置,第二个和倒数第二个互换位置,以此类推,所以可以定义两个指针,左指针从下标0开始,依次向右+1,右指针从末尾开始,依次向左-1,每次都调换指针对应的字符,直到左指针>=右指针(为什么是大于等于呢?当字符串长度为奇数时,左指针=右指针的时候可以结束计算;当字符串长度为偶数时,左指针>右指针的时候可以结束计算)

相关文章

实现字符串的反转。如:abcd 输出dcba

public class StringReverse { // 方法1: 使用 StringBuilder 的 reverse() 方法 (推荐,高效简洁) public stati...

JAVA 反转链表

输入一个链表,反转链表后,输出新链表的表头。/*public class ListNode { int val; ListNode next = null; ListNode(int val) { t...

剑指Offer (十五):反转链表(Java版)

对于一个单向链表来说,上一条数据只能指向下一条数据(如下图),那我们想反转这个链表,变成下图这个样子,怎么实现呢?1->2->3->4->5 5->4->...

几经反转 谷歌胜诉后甲骨文能否接招?丨C位

超过十年的 Java 版权大战在几经反转之后,最终以谷歌的胜利告终。而之后,谷歌的母公司Alphabet还计划在未来几周停用甲骨文的财务软件。面对谷歌的“落井下石”,营收增速放缓的甲骨文能否接招?点击...

Java面试中常见的算法题型

Java面试中常见的算法题型各位小伙伴们,今天咱们来聊聊Java面试中那些让人“脑细胞爆炸”的算法题!这些题目看似简单,但如果你没做好准备,它们可能会像一条条调皮的小泥鳅一样从你的指缝中溜走。不过别担...

Java面试场景题及答案最全总结(2025版持续更新)

大家好,我是Java面试陪考员最近很多小伙伴在忙着找工作,给大家整理了一份非常全面的Java面试题及答案。涉及的内容非常全面,包含:并发编程、Web、SpringBoot、MySQL、Linux、Sp...