由于中排和最大排的星星有9颗星,因此您应该使之
n等于9。您可以打印出一半的菱形,但是现在您必须尝试制作一个可以打印特定数量的空格的函数,然后具体数量的星星。因此,请尝试开发一种模式,使每行中的空格和星星数量增加,
Row1: 4 spaces, 1 star, 4 spacesRow2: 3 spaces, 3 stars, 3 spacesRow3: 2 spaces, 5 stars, 2 spacesRow4: 1 space, 7 stars, 1 spaceRow5: 0 spaces, 9 stars, 0 spacesRow6: 1 space, 7 stars, 1 spaceRow7: 2 spaces, 5 stars, 2 spacesRow8: 3 spaces, 3 stars, 3 spacesRow9: 4 spaces, 1 star, 4 spaces
那你能推断出什么呢?从第1行到(n + 1)/ 2,空间的数量随着恒星数量的增加而减少。因此从1到5,
# of stars=(
row number*
2)-1,而
# of spaces before stars= 5-
row number。
现在,从第(n + 1)/ 2 + 1到第9行,空间的数量增加,而星星的数量减少。所以从6到n,
# of stars=(((n + 1-
rownumber)* 2)-1,而
# of spaces before stars=
row number-5。
从这些信息中,您应该能够制作一个看起来像这样的程序,
n = 9print("Pattern 1")for a1 in range(1, (n+1)//2 + 1): #from row 1 to 5 for a2 in range((n+1)//2 - a1): print(" ", end = "") for a3 in range((a1*2)-1): print("*", end = "") print()for a1 in range((n+1)//2 + 1, n + 1): #from row 6 to 9 for a2 in range(a1 - (n+1)//2): print(" ", end = "") for a3 in range((n+1 - a1)*2 - 1): print("*", end = "") print()
请注意,您可以将n替换为任何奇数,以创建具有这么多行的完美菱形。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)