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

相关推荐
毕设源码-邱学长1 小时前
【开题答辩全过程】以 基于Java的学校住宿管理系统的设计与实现为例,包含答辩的问题和答案
java·开发语言
rookieﻬ°2 小时前
PHP框架漏洞
开发语言·php
猿界零零七2 小时前
pip install mxnet 报错解决方案
python·pip·mxnet
炸膛坦客3 小时前
单片机/C/C++八股:(二十)指针常量和常量指针
c语言·开发语言·c++
I_LPL3 小时前
hot100贪心专题
数据结构·算法·leetcode·贪心
兑生3 小时前
【灵神题单·贪心】1481. 不同整数的最少数目 | 频率排序贪心 | Java
java·开发语言
颜酱3 小时前
DFS 岛屿系列题全解析
javascript·后端·算法
WolfGang0073214 小时前
代码随想录算法训练营 Day16 | 二叉树 part06
算法
炸膛坦客4 小时前
单片机/C/C++八股:(十九)栈和堆的区别?
c语言·开发语言·c++
零雲4 小时前
java面试:了解抽象类与接口么?讲一讲它们的区别
java·开发语言·面试