问题描述:有一组浮点数,将其每行打印一个,要求纵向小数点对齐,并小数点前位数最大的数紧贴左边界。
例如:-3.14;0.7177;1586.23;10000.0;-587643.1;12.34565
思想:
1,以’.’作为分隔符,进行拆分,返回一个列表,
2,用m保存小数点前面的值,用k保存小数点后面的部分,分别求出最长度,进行对齐操作
3,,利用ljust(),rjust()进行对齐操作,不足的长度自动补充空格
a = [-3.14,0.7177,1586.23,10000.0,-587643.1,12.34565]
#每日一题102
def duiqi(array):
m = []
n = []
k = []
result = []
a1 = [str(i) for i in array]
#print(a)
for i in a1 :
m.append(i.split('.'))
n.append(i.split('.')[0])
k.append(i.split('.')[1])
#求所以长度中最长的数,不分正负数,进行对齐
long_font = max([len(i) for i in n])
long_rear = max([len(i) for i in k])
for each in m:
#对齐,对齐rjust,ljust,以空格补充不足位置的地方
result.append(each[0].rjust(long_font)+'.'+each[1].ljust(long_rear))
return result
duiqi(a)
另一种简易写法
def convertFit(alist):
widths = [len(str(int(x))) for x in alist]
maxw = max(widths)
#enumerate 函数用于遍历序列中的元素以及它们的下标
for i, f in enumerate(alist):
print(' '*(maxw-widths[i]) + str(f))
convertFit([-3.14,0.7177,1586.23,10000.0,-587643.1,12.34565])