Python 助力找出字符串中数字拼成的最大正整数!
以下是使用 Python 实现的代码: ```python # 读取输入的字符串 s = input() # 提取字符串中的所有数字 digits = [] for char in s: if char.isdigit() and int(char) != 0: # 提取 1 - 9 的数字 digits.append(int(char)) # 对数字列表进行降序排序 digits.sort(reverse=True) # 将排序后的数字列表转换为字符串 result_str = ''.join(map(str, digits)) # 输出结果 print(int(result_str)) ``` 代码解释: 1. 提取数字:遍历输入的字符串 `s`,使用 `isdigit()` 方法检查字符是否为数字,并且排除数字 `0`,将符合条件的数字添加到列表 `digits` 中。 2. 排序:对 `digits` 列表进行降序排序,这样可以确保最终组成的数字是最大的。 3. 转换为字符串:使用 `join()` 方法将排序后的数字列表转换为字符串。 4. 输出结果:将字符串转换为整数并输出。 复杂度分析: - 时间复杂度:$O(n log n)$,其中 $n$ 是字符串中数字的数量。主要的时间开销在于排序操作。 - 空间复杂度:$O(n)$,主要用于存储提取的数字。 ######[AI问答 | 315点数解答 | 2025-11-02 19:30:00]
相关提问
- C++ 求解:最少操作次数让字符串无子串 “friend” (字节豆包 | 153点数解答 | 2024-08-17 16:29:54)483
- C++ 求解:最少操作次数让字符串不再含 “friend” 子串!(讯飞星火 | 260点数解答 | 2024-08-17 16:30:49)472
- Python 巧解:最少操作次数让字符串告别“friend”子串(字节豆包 | 139点数解答 | 2024-08-18 13:04:14)408
- 3414 数字游戏:Python 求解 8 位 01 字符串中 1 的个数 (字节豆包 | 106点数解答 | 2024-10-27 14:23:27)433
- 巧用字符添加,计算字符串中“our”最大数量及开发注意要点(DeepSeek | 376点数解答 | 2025-10-30 19:20:06)82
- C 语言实现:处理字符串生成最多 “our” 串,附代码及关键开发注意点 (DeepSeek | 257点数解答 | 2025-10-30 19:20:36)113
- Python 运行报错:urllib3 网络连接创建失败,原因及排查建议(字节豆包 | 161点数解答 | 2024-10-31 00:39:36)468
- C++ 实现:精准统计给定范围 [L, R] 内数字 2 出现的次数及代码详解(字节豆包 | 401点数解答 | 2026-02-05 21:17:05)46
- C++实现:统计[L, R]范围内数字2出现的次数及代码详解(字节豆包 | 489点数解答 | 2026-02-07 17:12:26)56
- 高考毕业晚会难题:从学生能力值求最大默契程度的Python解法(字节豆包 | 487点数解答 | 2026-01-24 13:10:18)45
- Python 实战:学生信息列表转字典、遍历、深拷贝及数据修改全流程(GPT | 422点数解答 | 2024-10-29 15:43:54)425
- Python实战:学生成绩列表转字典,深拷贝与数据修改操作全解析(字节豆包 | 254点数解答 | 2024-10-29 16:01:39)417