Python 星星 金字塔 学习笔记

作为刚开始学习Python,很多小知识点都能看懂,但是一动代码就无语,所以遇到for循环的星星金字塔又卡住了,经过3个小时终于搞明白for嵌套for和一些算法的问题特次做一下笔记

第一种实现方式

n = int(input('请输入你需要打印星星的层数:'))
for i in range(1,n+1):
    print(' '*(n-(i-1))+'*'*(2*i-1))

分析:  每行有空格和星星组成,也就是逐行打印星星和空格即可
     发现星星的每层的个数是第一个是1,3,5,7。
   每层空格是总层数减相应的层数()

先研究算法

这也是为什么很多代码看得懂,拿上手也不知道怎么写,
所以每一个要解决的问题,首先先画图看算法,研究出来以后再去实现代码就ok
假设需要打印4层星星(金字塔形式)
1.从纵向来看每一层的星星是1,3,5,7
2.从横向来看每一层的空格是3,2,1,0
(星星后面的空格不用管,因为空格后面打印星星后自然不
会现实任何字符,也就是相当于是空格,所以只要保证前面
的空格数是正确就可以保证后面的正确数

l = int(input("请输入你需要的层数:"))
for i in range(1,l+1):
    print((l-i)*" ",end="")#打印空格
    print((2*i-1)*"*")#打印星号

输出结果:

***** *******

如果看不懂空格是如何实现的可以改变代码为如下:

l = int(input("请输入你需要的层数:"))
for i in range(1,l+1):
    print((l-i)*"k",end="")#打印空格
    print((2*i-1)*"*")#打印星号

输出结果:

kk*** k***** ******* 不管是for嵌套for循环还是直接print输出,都逃不过对空格和星号的操作,原理都一样。