算法刷题LeetCode中文版_leetcode100题

算法刷题LeetCode中文版_leetcode100题算法题打卡:仅仅反转字母。没有特别幸运,那么请先特别努力,别因为懒惰而失败,还矫情地将原因归于自己倒霉。所以说,树倒了,没有一片雪花是无辜的

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

请添加图片描述


?前言

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

?原题样例:仅仅反转字母

给定一个字符串 S,返回 “反转后的” 字符串,其中不是字母的字符都保留在原地,而所有字母的位置发生反转。

示例1:

输入:"ab-cd"
输出:"dc-ba"

示例2:

输入:"a-bC-dEf-ghIj"
输出:"j-Ih-gfE-dCba"

示例3:

输入:"Test1ng-Leet=code-Q!"
输出:"Qedo1ct-eeLg=ntse-T!"

提示:

  • S.length <= 100
  • 33 <= S[i].ASCIIcode <= 122
  • S 中不包含 \ or “

?C#方法:循环遍历

两次循环,一次添加字母,一次添加其他

代码:

public class Solution 
{ 
   
    public string ReverseOnlyLetters(string s) 
    { 
   
        string result = "";
        int n = s.Length;
        for (int i = n - 1; i >= 0; i--)
        { 
   
            if (char.IsLetter(s[i])) result += s[i];
        }
        for (int i = 0; i < n; i++)
        { 
   
            if (!char.IsLetter(s[i])) 
                result = result.Insert(i, s[i].ToString());
        }
        return result;
    }
}

执行结果

通过
执行用时:88 ms,在所有 C# 提交中击败了47.14%的用户
内存消耗:35.9 MB,在所有 C# 提交中击败了8.70%的用户

?Java 方法:字母栈

思路解析
将 s 中的所有字母单独存入栈中,所以出栈等价于对字母反序操作。(或者,可以用数组存储字母并反序数组。)

然后,遍历 s 的所有字符,如果是字母我们就选择栈顶元素输出。

代码:

class Solution { 
   
    public String reverseOnlyLetters(String S) { 
   
        Stack<Character> letters = new Stack();
        for (char c: S.toCharArray())
            if (Character.isLetter(c))
                letters.push(c);

        StringBuilder ans = new StringBuilder();
        for (char c: S.toCharArray()) { 
   
            if (Character.isLetter(c))
                ans.append(letters.pop());
            else
                ans.append(c);
        }

        return ans.toString();
    }
}

执行结果

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

复杂度分析

时间复杂度:O( n ),其中 NS 的长度。
空间复杂度:O(n) 

?总结

  • 今天是力扣算法题打卡的第105天!
  • 文章采用 C#Java 两种编程语言进行解题
  • 一些方法也是参考力扣大神写的,也是边学习边分享,再次感谢算法大佬们
  • 那今天的算法题分享到此结束啦,明天再见!
    请添加图片描述
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/183760.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • vscode配置java环境变量_vscode java环境

    vscode配置java环境变量_vscode java环境VScode配置Java环境小白成功配置完Java环境后的自我记录VScode下载在vscode官网:https://code.visualstudio.com/选择相应版本下载安装JDK下载vscode仅支持JDK11及以上版本JDK11下载:https://www.oracle.com/java/technologies/javase-jdk11-downloads.html可选择其他更高版本配置环境变量找到JDK安装的文件路径,复制文件路径在桌面上找到此电脑右键属性点

    2022年9月27日
    0
  • 如何使用Docker Compose安装Drupal

    如何使用Docker Compose安装DrupalTheauthorselectedUnitedNationsFoundationtoreceiveadonationaspartoftheWriteforDOnationsprogram.作者选择联合国基金会作为WriteforDOnations计划的一部分接受捐赠。TheoriginalWordPressversionofthistut…

    2022年7月20日
    17
  • C语言小游戏之扫雷完整版

    C语言小游戏之扫雷完整版C语言小游戏之扫雷一.游戏介绍二.游戏步骤及实现的功能1.初始化雷盘2.打印雷盘3.随机布置雷4.玩家排雷5.防止玩家第一次被炸死6.统计所选位置周围八个位置中雷的个数7.拓展已选位置周围的区域8.标记雷及取消标记一.游戏介绍看到这张图片,相信很多小伙伴都非常熟悉,很多小伙伴都玩过扫雷这个小游戏,扫雷是一款益智类游戏,在放松娱乐的同时可以锻炼各位小伙伴的智商。游戏规则:如上图,玩家需要在不被炸死的前提下找出图中雷的位置,若能找出所有雷,则游戏胜利,若不幸踩到雷则被炸死。注:先介绍,后文会有完整代码

    2022年5月19日
    39
  • Linux下如何解压rar文件「建议收藏」

    Linux下如何解压rar文件「建议收藏」在windows下我们压缩解压文件通常后缀为rar,在linux下我们压缩解压文件通常后缀为tar默认在linux下我们不能解压压缩rar文件,那我们如何使用呢?我们可以下载rarlinux安装包

    2022年6月30日
    19
  • visual studio code使用方法_vscode自定义代码块

    visual studio code使用方法_vscode自定义代码块snippet,也即代码片,指的是能够帮助输入重复代码模式,比如循环或条件语句,的模板。本文即旨于详实地介绍如何在vscode中设置snippet。

    2022年10月2日
    0
  • 安防监控必备的基础知识「建议收藏」

    安防监控必备的基础知识「建议收藏」安防监控必备的基础知识 什么是云镜控制解码器?答:解码器是将前端发出的控制信号转换为电压信号从而控制云台、镜头的的装置。什么是同轴电缆?答:同轴电缆(COARIALCABLE)的得名与它的结构相关。同轴电缆也是监控中最常见的传输介质之一。它用来传递信息的一对导体是按照一层圆筒式的外导体套在内导体(一根细芯)外面,两个导体间用绝缘材料互相隔离的结构制选的,外层导体和中心轴芯线的…

    2022年4月19日
    44

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号