码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Leetcode 1417. Reformat The String


    文章作者:Tyan
    博客:noahsnail.com  |  CSDN  |  简书

    1. Description

    Reformat The String

    2. Solution

    **解析:**Version 1,先分离数字和字母,如果二者数量差的绝对值大于1,则不可能形成字母数字字符串,否则,根据数量多少,按顺序依次连接字符数字数组即可。

    • Version 1
    class Solution:
        def reformat(self, s: str) -> str:
            letters = []
            digits = []
            for ch in s:
                if ch.isalpha():
                    letters.append(ch)
                else:
                    digits.append(ch)
    
            diff = len(letters) - len(digits)
            if abs(diff) > 1:
                return ''
            elif diff == 0 or diff == 1:
                arr1 = letters
                arr2 = digits
            else:
                arr1 = digits
                arr2 = letters
    
            result = [0] * len(s)
            for i in range(len(arr1)):
                result[i * 2] = arr1[i]
            for i in range(len(arr2)):
                result[i * 2 + 1] = arr2[i]
            return ''.join(result)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26

    **解析:**Version 2,进一步优化。

    • Version 2
    class Solution:
        def reformat(self, s: str) -> str:
            letters = 0
            digits = 0
            for ch in s:
                if ch.isalpha():
                    letters += 1
                else:
                    digits += 1
    
            diff = letters - digits
            if abs(diff) > 1:
                return ''
            elif diff == 0 or diff == 1:
                i = 0
                j = 1
            else:
                i = 1
                j = 0
            
            result = [0] * len(s)
            for ch in s:
                if ch.isalpha():
                    result[i] = ch
                    i += 2
                else:
                    result[j] = ch
                    j += 2
            
            return ''.join(result)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30

    **解析:**Version 2,使用双指针,分别从两端找起,如果碰到字母和数字不符合当前位置,则交换二者。

    • Version 3
    class Solution:
        def reformat(self, s: str) -> str:
            letters = 0
            digits = 0
            for ch in s:
                if ch.isalpha():
                    letters += 1
                else:
                    digits += 1
    
            diff = letters - digits
            if abs(diff) > 1:
                return ''
            elif diff == 0 or diff == 1:
                i = 0
                j = len(s) - 2
            else:
                i = 1
                j = len(s) - 1
            
            result = list(s)
    
            while i < len(s) and j >=0:
                while i < len(s) and result[i].isalpha():
                    i += 2
                while j >=0 and result[j].isdigit():
                    j -= 2
                if i < len(s) and j >=0:
                    result[i], result[j] = result[j], result[i]
            
            return ''.join(result)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31

    Reference

    1. https://leetcode.com/problems/reformat-the-string/
  • 相关阅读:
    CV算法工程师的LLM日志(1)微调技术——即插即用的neft-Tune【原理&&代码】
    进阶JAVA篇-如何理解作为参数使用的匿名内部类与 Arrays 类的常用API(九)
    CSS基础(9)- 行盒的盒模型
    Linux之yum安装MySQL
    python扩展包安装失败解决方案
    Hive SQL初级练习(30题)
    中国传统节日春节网页HTML代码 春节大学生网页设计制作成品下载 学生网页课程设计期末作业下载 DW春节节日网页作业代码下载
    Spark【Spark SQL(二)RDD转换DataFrame、Spark SQL读写数据库 】
    软件项目管理 8.4.软件项目质量计划
    全国计算机等级考试二级考试(Python)题库
  • 原文地址:https://blog.csdn.net/Quincuntial/article/details/126272654
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号