洛谷题单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 输出最终结果 结束

相关推荐
Jay Kay6 小时前
GVPO:Group Variance Policy Optimization
人工智能·算法·机器学习
Mr_sun.6 小时前
Day09——入退管理-入住-2
android·java·开发语言
Epiphany.5566 小时前
蓝桥杯备赛题目-----爆破
算法·职场和发展·蓝桥杯
MAGICIAN...6 小时前
【java-软件设计原则】
java·开发语言
gpfyyds6666 小时前
Python代码练习
开发语言·python
YuTaoShao6 小时前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法三)DP 空间优化
算法·leetcode·职场和发展
盐真卿6 小时前
python第八部分:高级特性(二)
java·开发语言
茉莉玫瑰花茶6 小时前
C++ 17 详细特性解析(5)
开发语言·c++·算法
lly2024066 小时前
《堆的 shift down》
开发语言
cpp_25016 小时前
P10570 [JRKSJ R8] 网球
数据结构·c++·算法·题解