20181210Python 自动化笔试题,挑战你的知识库

本贴最后更新于 1520 天前,其中的信息可能已经时移俗易

image.png

柠檬班学员面试遇到的笔试题!!!
出招吧各位大佬!

26 回帖
请输入回帖内容 ...
  • tyh498366331

    大佬,这个方法厉害,我怎么没想到

  • 其他回帖
  • mmklyz

    早上花了差不多一个小时,才搞出来,如果面试,啊,磨磨唧唧肯定写不出来。主要是算空格 * 和行的关系。代码中区分了n为奇数或偶数的情况。附上代码:
    image.png

    n=9时:
    image.png

    n=10的时候:
    image.png

  • D_Sai
    # -*- coding: UTF-8 -*-
    # @Author: Sai_Python12
    # @Email: 932934045@qq.com
    # @File: StarStar.py
    
    class MyStar:
        '''星星类'''
        def __init__(self, n):
            self.n = n
            self.data_1 = [] #存放上半部左侧空格数量
            self.data_2 = [] #存放上半部星号数量
    
        def my_star(self):
            K = int((self.n+1)/2) #K 为上部一半
            for i in range(1, K+1):#i 为行数
                self.data_1.append(K-i)
                self.data_2.append(2*i-1)
                print(' '*self.data_1[i-1] + '*'*self.data_2[i-1])
    
            if self.n % 2 == 0:
                for i in range(1, K+1):
                    print(' '*self.data_1[-i] + '*'*self.data_2[-i])
            else:
                for i in range(1, K):
                    print(' '*self.data_1[-i-1] + '*'*self.data_2[-i-1])
            print(self.data_1)
            print(self.data_2)
    
    if __name__ == '__main__':
        MyStar(6).my_star()
    

    image.png
    image.png

  • Chouchiehlun257248
    # 镜像星星金字塔
    def mirror_star_pyramid(n):
        i = 1# 给定初始值
        star_list1 = []# 存正金字塔每一层元素
        star_list2 = []# 存倒金字塔每一层元素
        while i <= n:
            star_list1.append(' '*((n-i)//2) + '*'*i + ' '*((n-i)//2))
            # n的奇偶性将决定倒金字塔的元素是跟正金字塔一样还是比正金字塔少一层
            if n % 2:
                star_list2.append(' '*((i+1)//2) + '*'*(n-i-1) + ' '*((i+1)//2))
            else:
                star_list2 = star_list1[::-1]
            i += 2
        for each in star_list1:print(each)
        for each in star_list2:print(each)
    
    if __name__ == '__main__':
        mirror_star_pyramid(5)
        mirror_star_pyramid(6)
    
  • 查看更多回帖