使用Python制作钻石ASCII艺术
问题内容:
我在制作这颗钻石时遇到麻烦。每当我使字符等于偶数长度时,结果就很好。但是,当它很奇怪时,只会将钻石的底部弄乱。我已经为此工作了几个小时,几乎完成了。先谢谢您的帮助。
chars = 'ABCDEF'
length = len(chars)
string = ''
dots = (length*2 - 1)*2 - 1
for i in range(length):
string1 = ''
string += chars[i]
length1 = len(string)
for j in range(0, length1):
if j % 2 != 0:
string1 += chars[length -1 - j].center(3, '.')
else:
string1 += chars[length - 1 - j]
for k in range(i - 1, -1, -1):
if k % 2 != 0:
string1 += chars[length - 1 - k].center(3, '.')
else:
string1 += chars[length - 1 - k]
string1 = string1.center(dots, '.')
print(string1)
string=''
for i in range(length - 1):
string1 = ''
string += chars[i]
length1 = len(string)
for j in range(length - 1 - i):
if j % 2 != 0:
string1 += chars[length - 1 - j]
else:
string1 += chars[length -1 - j].center(3, '.')
for k in range(i + 2, length):
if k % 2 != 0:
string1 += chars[k].center(3, '.')
else:
string1 += chars[k]
string1 = string1.center(dots, '.')
print(string1)
当字符长度为奇数时
当字符长度为偶数时
问题答案:
这是python。您可以使用许多有用的字符串函数,以少量的代码行来创建创造性的ASCII艺术。
一些最重要的问题是str.join
,str.Xjust
。我们还将利用chr
并ord
迭代字符范围。
首先,定义一个处理填充的函数。
def pad(c1, c2, sep='.', field_width=10):
out = sep.join(chr(x) for x in range(c2, c1, -1)).rjust(field_width, sep) # build the first part
return sep.join([out, chr(c1), out[::-1]])
第一行代码将构建菱形行的前半部分。第二行将上半部分与中心字母和上半部分的反向版本连接在一起。
接下来,确定范围-钻石的大小。
start = 'A'
end = ...
field_width = (ord(end) - ord('A')) * 2 - 1
现在,您将需要两个单独的循环-一个循环用于上面的菱形,另一个循环用于下面的菱形。两个循环都pad
在每次迭代时调用。
for e in range(ord(end), ord(start), -1):
print(pad(e, ord(end), '.', field_width))
for e in range(ord(start), ord(end) + 1):
print(pad(e, ord(end), '.', field_width))
end = 'E'
:
........E........
......E.D.E......
....E.D.C.D.E....
..E.D.C.B.C.D.E..
E.D.C.B.A.B.C.D.E
..E.D.C.B.C.D.E..
....E.D.C.D.E....
......E.D.E......
........E........
end = 'F'
:
..........F..........
........F.E.F........
......F.E.D.E.F......
....F.E.D.C.D.E.F....
..F.E.D.C.B.C.D.E.F..
F.E.D.C.B.A.B.C.D.E.F
..F.E.D.C.B.C.D.E.F..
....F.E.D.C.D.E.F....
......F.E.D.E.F......
........F.E.F........
..........F..........
塞思·迪夫利(Seth
Difley)的答案
探索了一种替代方法,该方法包括制造钻石的上半部分并将其反转以获得下半部分。实际上,也可以将这种方法用于该解决方案,具体方法如下:
lines = []
for e in range(ord(end), ord(start) - 1, -1):
lines.append(pad(e, ord(end), '.', field_width))
for x in lines + lines[-2::-1]:
print(x)
这也导致相同的输出,并且速度更快。