python打印出1到10的数_Python打印1到最大的n位数

本文介绍了如何用Python实现从1打印到最大n位数的算法。通过两个函数`Print1ToMaxOfNDigits`和`Print1ToMaxOfNDigits2`,递归地增加数字字符串并打印,同时处理可能的溢出情况。在打印过程中,确保不会打印多余的前导0。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

要点是注意输入的n位数是否会导致溢出,因此利用字符串模拟整数的加法。注意:在打印函数中,需要判断打印的数字是否是以0开头的,同时判断条件是 num[i] != "0",不能写作 num[i] != 0,因为是使用str类型的,后面一种写法导致判断无法成功。'''

输入数字n, 按顺序打印从1最大的n位十进制数

比如输入3, 则打印出1、2、3、到最大的3位数即999

'''

def Print1ToMaxOfNDigits(n):

if n <= 0:

return

number = ['0'] * n

while not Increment(number):

PrintNumber(number)

def Increment(number):

isOverflow = False

nTakeOver = 0

nLength = len(number)

for i in range(nLength-1, -1, -1):

nSum = int(number[i]) + nTakeOver

if i == nLength - 1:

nSum += 1

if nSum >= 10:

if i == 0:

isOverflow = True

else:

nSum -= 10

nTakeOver = 1

number[i] = str(nSum)

else:

number[i] = str(nSum)

break

return isOverflow

def PrintNumber(number):

isBeginning0 = True

nLength = len(number)

for i in range(nLength):

if isBeginning0 and number[i] != '0':

isBeginning0 = False

if not isBeginning0:

print('%c' % number[i], end='')

print('')

#

# Print1ToMaxOfNDigits(2)

def Print1ToMaxOfNDigits2(n):

if n <= 0:

return

number = ['0'] * n

for i in range(10):

number[0] = str(i)

Print1ToMaxOfNDigitsRecursively(number, n, 0)

def Print1ToMaxOfNDigitsRecursively(number, length, index):

if index == length - 1:

PrintNumber(number)

return

for i in range(10):

number[index + 1] = str(i)

Print1ToMaxOfNDigitsRecursively(number, length, index+1)

Print1ToMaxOfNDigits2(2)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值