小白菜學爬蟲(二):程序邏輯訓練

寫完第一篇之后,這幾天又處理了很多事情,租房、工作、維修。不禁感嘆自己還是得早點學好本事,增加收入,擁有自己的房子才行。租房太累,工作也不得踏實。吐槽完畢,安裝環(huán)境、語法基礎(chǔ)部分都跳過,直接到三個題目。

  1. 打印三角形
    分為三角形,倒三角形和等腰三角形

三角形

def triangle():
    n = int(input('please enter the length of triangle!'))
    for i in range(n):
        print("*"*(i+1))

triangle()

打印結(jié)果:

三角形.png

倒三角形

def z_triangle():
    n = int(input('please enter the length of triangle!'))
    for i in range(n,0,-1):
        print("*"*(i))

z_triangle()

打印結(jié)果:

倒三角形

等腰三角形

def equ_triangle():
    n = int(input('please enter the length of triangle!'))
    for i in range(n):
        print(" "*(n-i-1)+"*"*(2*i+1))

equ_triangle()

打印結(jié)果:

等腰三角形
  1. 求1000以內(nèi)的完全數(shù)有哪些

如果一個數(shù)恰好等于它的因子之和,則稱該數(shù)為“完全數(shù)”,又稱完美數(shù)或完備數(shù)。
例如:第一個完全數(shù)是6,它有約數(shù)1、2、3、6,除去它本身6外,其余3個數(shù)相加,1+2+3=6。第二個完全數(shù)是28,它有約數(shù)1、2、4、7、14、28,除去它本身28外,其余5個數(shù)相加,1+2+4+7+14=28。

1000以內(nèi)的完全數(shù)

def is_perfect(num):
    t=sum(x for x in range(1,int(num/2)+1) if num%x == 0)
    if t==num:
        print("%s is perfect number" % t)

for i in range(1,1000):
    is_perfect(i)

打印結(jié)果:

完全數(shù).png

3、打印萬年歷

打印萬年歷的條件
判斷是否為閏年
計算每種情況下,每個月份的天數(shù)
由2計算每年的天數(shù)
計算每月一日對應的星期,基于1990年1月1日是星期一

打印萬年歷

class Calendar(object):
    # 獲取需要打印的年月,并初始化賦值
    def __init__(self):
        self.year = int(input("請輸入查詢的年份(如:2010):"))
        self.month= int(input("請輸入查詢的月份(如:3):"))

    # 判斷是否是閏年
    def leap_year(self):
        if self.year%400==0 or (self.year%100==0 and self.year%4==0):
            return True

    # 判斷輸入月份的天數(shù)
    def days_of_month(self):
        if self.month in [1,3,5,7,8,10,12]:
            return 31
        elif self.month in [4,6,9,11]:
            return 30
        elif self.leap_year() == 'True':
            return 29
        else:
            return 28

    # 計算與19900101間隔的天數(shù)
    def days_between_19900101(self):
        sum_days = 0
        for y in range(1990, self.year + 1):
            # 閏年加366天
            if self.leap_year():
                sum_days += 366
            # 正常加365天
            else:
                sum_days += 365
        for m in range(1, self.month):
            sum_days += self.days_of_month()
        return sum_days

    # 判斷打印月份的第一天是星期幾
    def firstday_of_month(self):
        first_of_day = 1 + self.days_between_19900101() % 7
        return first_of_day

    # 打印日歷
    def print_cal(self):
        print(str(self.year) + "年  " + str(self.month) + "月  ")
        # 打印星期欄
        print("   "'星期一'"     " '星期二'"      "'星期三'"      "'星期四'"     "'星期五'"     "'星期六'"      "'星期日')
        d = self.firstday_of_month()
        print(('           ' * (d - 1)), end="")
        for p in range(1, self.days_of_month() + 1):
            if d % 7 != 0:
                # 按照長度不同空不同的距離,保證右對齊
                if len(str(p)) == 1:
                    print('     ', end="")
                    print(p, end='')
                    print('     ', end="")
                else:
                    print('    ', end="")
                    print(p, end='')
                    print('     ', end="")
            else:
                # 如果是周日,則下一個日期換行輸出顯示
                if len(str(p)) == 1:
                    print('     ', end="")
                    print(p)
                else:
                    print('    ', end="")
                    print(p)
            d = d + 1

if __name__ == '__main__':
    Cal = Calendar()
    Cal.print_cal()

打印結(jié)果:

打印日歷.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容