我是靠谱客的博主 缥缈方盒,最近开发中收集的这篇文章主要介绍[leetcode]5413. 重新排列句子中的单词,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

  • 个人博客:https://javaniuniu.com/
  • 难度:简单
  • 本题涉及算法:
  • 思路:lambda
  • 类似题型:

题目 5413. 重新排列句子中的单词

「句子」是一个用空格分隔单词的字符串。给你一个满足下述格式的句子 text :

  • 句子的首字母大写
  • text 中的每个单词都用单个空格分隔。
    请你重新排列 text 中的单词,使所有单词按其长度的升序排列。如果两个单词的长度相同,则保留其在原句子中的相对顺序。

请同样按上述格式返回新的句子。

示例 1:

输入:text = "Leetcode is cool"
输出:"Is cool leetcode"
解释:句子中共有 3 个单词,长度为 8 的 "Leetcode" ,长度为 2 的 "is" 以及长度为 4 的 "cool" 。
输出需要按单词的长度升序排列,新句子中的第一个单词首字母需要大写。

示例 2:

输入:text = "Keep calm and code on"
输出:"On and keep calm code"
解释:输出的排序情况如下:
"On" 2 个字母。
"and" 3 个字母。
"keep" 4 个字母,因为存在长度相同的其他单词,所以它们之间需要保留在原句子中的相对顺序。
"calm" 4 个字母。
"code" 4 个字母。

示例 3:

输入:text = "To be or not to be"
输出:"To be or to be not"

提示:

text 以大写字母开头,然后包含若干小写字母以及单词间的单个空格。
1 <= text.length <= 10^5

方法一 按照元素长度排序

  • 使用 lambda 轻松搞定排序
class Solution:
    def arrangeWords(self, text: str) -> str:
        text = text.lower() # 首字母转小写
        text = text.split(" ") # 通过 空格 分割成数组
        text.sort(key=lambda x: len(x)) # 使用 lambda 按照元素长度排序
        return ' '.join(text).capitalize() # 最后首字母大写
  • 如果你觉得本文对你有帮助,请点赞????支持
  • 如果有疑惑或者表达不到位的额地方 ,请在下面????评论区指出

最后

以上就是缥缈方盒为你收集整理的[leetcode]5413. 重新排列句子中的单词的全部内容,希望文章能够帮你解决[leetcode]5413. 重新排列句子中的单词所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(54)

评论列表共有 0 条评论

立即
投稿
返回
顶部