洛谷题单3-P1307 [NOIP 2011 普及组] 数字反转-python-流程图重构

题目描述

给定一个整数 N N N,请将该数各个位上数字反转得到一个新数。新数也应满足整数的常见形式,即除非给定的原数为零,否则反转后得到的新数的最高位数字不应为零(参见样例 2)。

输入格式

一个整数 N N N。

输出格式

一个整数,表示反转后的新数。

输入输出样例

输入

复制代码
123

输出

复制代码
321

说明/提示

【数据范围】

-1,000,000,000\\leq N\\leq 1,000,000,000

方式

代码

python 复制代码
class Solution:
    @staticmethod
    def oi_input():
        """从标准输入读取数据"""
        num = input().strip()
        return num

    @staticmethod
    def oi_test():
        """提供测试数据"""
        return "123"

    @staticmethod
    def solution(num):
        if num == '0':
            print(0)
        else:
            sign = '-' if num.startswith('-') else ''  # 符号
            num_str = num[1:] if sign else num  # 数值
            reversed_str = num_str[::-1].lstrip('0')  # 反转加除去左边的零
            print(sign + reversed_str)


oi_input = Solution.oi_input
oi_test = Solution.oi_test
solution = Solution.solution

if __name__ == '__main__':
    num = oi_test()
    # num = oi_input()
    solution(num)

流程图

是 否 是 否 开始 输入数字字符串num num == '0'? 输出0 提取符号sign
sign = '-' if num以'-'开头 else '' 提取数值部分num_str
num_str = num1: if sign存在 else num 反转并去除前导零
reversed_str = num_str::-1.lstrip('0') reversed_str为空? reversed_str = '0' 保持reversed_str不变 组合结果: sign + reversed_str 输出最终结果 结束

相关推荐
荣码32 分钟前
LangGraph多Agent协作:3个Agent干活比1个强,但我踩了4个坑
java·python
To_OC11 小时前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安16 小时前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法
用户83562907805116 小时前
Python 操作 PDF 附件:添加、查看与管理指南
后端·python
七牛开发者18 小时前
MCP 到底是什么?为什么 Agent 都想接上它
算法·aigc·agent
宇宙之一粟1 天前
乐企版式文件生成平台
java·后端·python
kisshyshy1 天前
从递归到迭代,一文吃透二叉树的核心知识与 JavaScript 实现
javascript·算法·代码规范
To_OC1 天前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode