IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> 翻转字符串里的单词python(leetcode151) -> 正文阅读

[Python知识库]翻转字符串里的单词python(leetcode151)

#151. 翻转字符串里的单词

输入:s = "the sky is blue"
输出: "blue is sky the"
  • 输入字符串?s?可以在前面、后面或者单词间包含多余的空格。
  • 翻转后单词间应当仅用一个空格分隔。
  • 翻转后的字符串中不应包含额外的空格

#?当使用split()函数时

class Solution(object):
        # 当使用split()函数时
    def reverseWords(self, s):
        s = s.split()
        s = list(s)
        l, r = 0, len(s) - 1
        while(l < r):
            s[l], s[r] = s[r], s[l]
            l += 1
            r -= 1
        return ' '.join(s)

????#?不使用split()函数

????#?3步?1去除多余空格?2?字符串整体翻转?3?单词再翻转

class Solution:
    # 不使用split()函数
    # 3步 1去除多余空格 2 字符串整体翻转 3 单词再翻转

    # 1去除多余空格
    def remove_space(self, s):
        l, r = 0, len(s) - 1
        # 去除单词两端的空格
        while(l < r and s[l] == ' '):
            l += 1
        while(l < r and s[r] == ' '):
            r -= 1
        
        # 已经删除了两端空格,再删除单词间的空格
        s_new = []
        while(l <= r):
            if s[l] != ' ':
                s_new.append(s[l])
            elif(s[l] == ' ' and s[l - 1] != ' '):
                s_new.append(s[l])
            l += 1
        return s_new
    
    # 2 字符串整体翻转
    def reverse_str(self, s):
        l, r = 0, len(s) - 1
        while l < r:
            s[l], s[r] = s[r], s[l]
            l += 1
            r -= 1
        return s  

    # 3 翻转单词
    def reverse_each_words(self, s):
        l, r = 0, 0
        while l < len(s):
            while(r < len(s) and s[r] != ' '):
                # 找到空格前的位置
                r += 1
            s[l : r] = self.reverse_str(s[l : r])    
            l = r + 1
            r += 1
        return s
    def reverseWords(self, s):
        """
        :type s: str
        :rtype: str
        """
        s = self.remove_space(s)
        s = self.reverse_str(s)
        s = self.reverse_each_words(s)
        return ''.join(s)

  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2021-12-23 15:43:22  更:2021-12-23 15:43:58 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/16 4:12:29-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码