洛谷题单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 = num[1:] if sign存在 else num 反转并去除前导零
reversed_str = num_str[::-1].lstrip('0') reversed_str为空? reversed_str = '0' 保持reversed_str不变 组合结果: sign + reversed_str 输出最终结果 结束

相关推荐
君义_noip12 小时前
信息学奥赛一本通 1661:有趣的数列 | 洛谷 P3200 [HNOI2009] 有趣的数列
c++·算法·组合数学·信息学奥赛·csp-s
leaves falling12 小时前
C语言内存函数-
c语言·开发语言
程序员:钧念12 小时前
深度学习与强化学习的区别
人工智能·python·深度学习·算法·transformer·rag
数据与后端架构提升之路12 小时前
TeleTron 源码揭秘:如何用适配器模式“无缝魔改” Megatron-Core?
人工智能·python·适配器模式
英英_13 小时前
MATLAB数值计算基础教程
数据结构·算法·matlab
一起养小猫13 小时前
LeetCode100天Day14-轮转数组与买卖股票最佳时机
算法·leetcode·职场和发展
至为芯13 小时前
IP6537至为芯支持双C口快充输出的45W降压SOC芯片
c语言·开发语言
hele_two13 小时前
快速幂算法
c++·python·算法
小羊羊Python14 小时前
SoundMaze v1.0.1正式发布!
开发语言·c++
浩瀚地学14 小时前
【Java】JDK8的一些新特性
java·开发语言·经验分享·笔记·学习