【算法千题案例】每日LeetCode打卡——66.反转字符串

发布时间:2022-07-01 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了【算法千题案例】每日LeetCode打卡——66.反转字符串脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

        • 📢前言
    • 🌲原题样例F1a;反转字符串
      • 🌻C#方法:双指针
      • 🌻Java 方法:双指针
    • 💬总结

【算法千题案例】每日LeetCode打卡——66.反转字符串


📢前言

🚀 算法题 🚀
  • 🌲 每天打卡一道算法题,既是一个学习过程,又是一个分享的过程😜
  • 🌲 提示:本专栏解题 编程语言一律使用 C# 和 Java 两种进行解题
  • 🌲 要保持一个每天都在学习的状态,让我们一起努力成为算法大神吧🧐!
  • 🌲 今天是力扣算法题持续打卡第66天🎈!
🚀 算法题 🚀

🌲原题样例:反转字符串

编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 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 码表中的可打印字符

🌻C#方法:双指针

首尾指针一同向中间移动,交换元素

代码:

public class Solution {
    public void reverseString(char[] s) {
        char head;
        char tail;
        for(int i=0;i<s.Length/2;i++)
        {
            head=s[i];
            tail=s[s.Length-1-i];
            s[s.Length-1-i]=head;
            s[i]=tail;
        }
    }
}

执行结果

通过
执行用时:88 ms,在所有 Java  提交中击败了22.50%的用户
内存消耗:36.4 MB,在所有 Java 提交中击败了12.50%的用户

🌻Java 方法:双指针

思路解析

【算法千题案例】每日LeetCode打卡——66.反转字符串

代码:

class Solution {
    public void reverseString(char[] s) {
        int n = s.length;
        for (int left = 0, right = n - 1; left < right; ++left, --right) {
            char tmp = s[left];
            s[left] = s[right];
            s[right] = tmp;
        }
    }
}

执行结果

通过
执行用时:1 ms,在所有 Java  提交中击败了90.26%的用户
内存消耗:45.2 MB,在所有 Java 提交中击败了8.05%的用户

复杂度分析

@R_717_1304@:O( n )
空间复杂度:O( 1 ) ,其中 Σ 是字符串的字符集。哈希表存储字符的空间取决于字符串的字符集大小,最坏情况下每个字符均不相同,需要O(∣Σ∣) 的空间。



💬总结

  • 今天是力扣算法题打卡的第六十六天!
  • 文章采用 C#Java 两种编程语言进行解题
  • 一些方法也是参考力扣大神写的,也是边学习边分享,再次感谢算法大佬们
  • 那今天的算法题分享到此结束啦,明天再见!

    【算法千题案例】每日LeetCode打卡——66.反转字符串

脚本宝典总结

以上是脚本宝典为你收集整理的【算法千题案例】每日LeetCode打卡——66.反转字符串全部内容,希望文章能够帮你解决【算法千题案例】每日LeetCode打卡——66.反转字符串所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。