【Python】基础习题100例(1-25例)_努力做最通俗易懂版本

前言:

Python 100个小测试,用于熟悉和巩固Python基础
例题地址:https://www.runoob.com/python/python-100-examples.html

# -*- coding: utf-8 -*-

"""
前言: 
Python 100个小测试 用于熟悉和巩固Python基础
runoob:https://www.runoob.com/python/python-100-examples.html 
知乎:https://zhuanlan.zhihu.com/p/260175468 

"""

""" 
题目1: 有四个数字:1、2、3、4,能组成多少个互不相同且无重复数字的三位数?各是多少?
"""
# 正常 
num =[]
for a in range(1,5):
    for b in range(1,5):
        for c in range(1,5):
            if (a != b and a!= c and b!=c) :  # if a != b != c  只判断了a不等于b,b不等于c,没有判断a和c的关系 
                num.append(a*100 + b*10 + c)
print(num) 

# 简写: 
x = [1,2,3,4]
num  = [i*100 + j*10 + k for i in x for j in x for k in x if (j != i and k != j and k != i)]

# itertools ,结果需处理 
import itertools
num = [] 
x=[1,2,3,4]
for i in itertools.permutations(x,3):
    num.append(i)
print(num) 


"""
题目2:企业发放的奖金根据利润提成。
利润(I)低于或等于10万元时,奖金可提10%;
利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提成7.5%;
20万到40万之间时,高于20万元的部分,可提成5%;
40万到60万之间时高于40万元的部分,可提成3%;
60万到100万之间时,高于60万元的部分,可提成1.5%,
高于100万元时,超过100万元的部分按1%提成,
从键盘输入当月利润I,求应发放奖金总数?
"""
# 比较简单,直接上答案 
def get_bonus(profit):
    bonus = 0
    if profit <= 100000:
        bonus = profit*0.1   # 不能写百分数7.5%,需转化为小数点
    elif 100000 < profit <= 200000:
        bonus = get_bonus(100000) + (profit-100000)*0.075   
    elif 200000 < profit <= 400000:
        bonus = get_bonus(200000) + (profit-200000)*0.05
    elif 400000 < profit <= 600000:
        bonus = get_bonus(400000) + (profit-400000)*0.03
    elif 600000 < profit <= 1000000:
        bonus = get_bonus(600000) + (profit-600000)*0.015
    else :
        bonus = get_bonus(1000000) + (profit-1000000)*0.01
    return bonus

get_bonus(1000000)


"""
题目3:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?
"""
分析: 
a + 100 = b**2 + 168 = c**2 
168 = c**2 - b**2  
因为b小于c,且b,c都属于168,所以b∈c 

for c in range(1,168):
    for b in range(1,c): 
        if c**2-b**2 == 168:
            a = b**2 - 100
            print(a)

"""
题目4:输入某年某月某日,判断这一天是这一年的第几天?
"""
分析:
1. 月份 += 天数;
2. 1,4,9,11月 固定30天,35681012月 固定31, 2月闰年28天,非润29;
3. 考虑系统语言计算差会存在1天误差,所以起始天数为1; 
def get_days(year,month,day):
    days = [31,28,31,30,31,60,31,31,30,31,30,31] 
    sum = 1    # 不能是0,日期从1开始算
    if year % 400 == 0 or (year % 4 == 0 and year % 100 != 0) :
        days[2] = days[2]+1
    else:
        days[2] = days[2]
    for i in range(month-1):
        sum += days[i]
    return sum 

get_days(2021,3,1)


"""
题目5:输入三个整数x,y,z,请把这三个数由小到大输出。
"""
def px_3(a,b,c):
    num = [a,b,c]
    num.sort()
    return num

px_3(1,8,2)

"""
题目6:斐波那契数列(Fibonacci sequence),又称黄金分割数列,指的是这样一个数列:0、1、1、2、3、5、8、13、21、34、……。
"""
从第3个数起,每一个数等于前2个数的和; 
num = f(n-1)+f(n-2) (n>=2)

def Fibonacci_sequence(n):
    a, b = 0, 1
    while n:
        a, b, n = b, a + b, n - 1
        print(a)
Fibonacci_sequence(10)


"""
题目8:输出 9*9 乘法口诀表。
"""
1*1=1
2*1=2 2*2=4
3*1=3 3*2=6  3*3=9
4*1=4 4*2=8  4*3=12 4*4=16
5*1=5 5*2=10 5*3=15 5*4=20 5*5=25
6*1=6 6*2=12 6*3=18 6*4=24 6*5=30 6*6=36
7*1=7 7*2=14 7*3=21 7*4=28 7*5=35 7*6=42 7*7=49
8*1=8 8*2=16 8*3=24 8*4=32 8*5=40 8*6=48 8*7=56 8*8=64
9*1=9 9*2=18 9*3=27 9*4=36 9*5=45 9*6=54 9*7=63 9*8=72 9*9=81

for a in range(1,10):
    for b in range(1,10):
        print( str(a),"*",str(b),"=",a*b )


"""
题目9:暂停一秒输出。
程序分析:使用 time 模块的 sleep() 函数。
"""
# 没有具体要求,能实现延迟即可; 
import time 

id = [1,2]
for i in range(len(id)):
    print(i)
    time.sleep(5)


"""
题目10:暂停一秒输出,并格式化当前时间。
"""
# 主要考察time的使用 2个函数
# 获取当前时间: time.localtime(time.time())
# 格式化时间: time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()) 

import time  # https://www.runoob.com/python/python-date-time.html
time.sleep(1)
print(time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()))


"""
题目11:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?
"""
分析: 
每一对新兔子的第3个月会数量裂变,所以这一对兔子第n月生的兔子数为: sum = 2+(n-2)*2; 第二个兔子对也遵循这个逻辑;
month = [1,2,3,4,5,6,7,8...]
rab_1 = [2,2,2,2,2,2,2,2...]
rab_2 = [0,0,2,2,4,6,8,10...]
rab_3 = [0,0,0,2,2,4,6,8...]
rab_4 = [0,0,0,0,2,2,4,6...]
rab_5 = [0,0,0,0,0,2,2,4]
rab_6 = [0,0,0,0,0,0,2,2]
rab_7 = [0,0,0,0,0,0,0,2]
...
汇总 = [2,2,4,6,10,16,26,42...]
从汇总可得,符合斐波那契数列的变式, 从官网看得理解题目和答案不匹配,一对=2 而不是1; 

def rabbits(n):
    if n==1 or n==2:
        return 2
    return rabbits(n-1)+rabbits(n-2)

rabbits(7)

"""
题目12:判断101-200之间有多少个素数,并输出所有素数。    
"""
分析: 
判断素数x方法:2-(x-1)之间能有一个数被整除 则非素数; 

num = []
for a in range(101,200):
    for b in range(2,a-1):
        if a%b == 0 :
            break 
    else:            # 这里位置不能写错,不然容易陷入无限循环; 
        num.append(a)
print(num) 


"""
题目13:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。
       例如:153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方。
"""
// 取整  % 取余 
num = []
for n in range(100,1000):
    a = n//100
    b = n//10%10   
    c = n%10 
    if n == a**3 + b**3 + c**3 :
        num.append(n)
print(num)


"""
题目14:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。
"""
分析:
要找出全部因数比较容易,第一次写输出的是[235],没有考虑到重复因子的情况,所以要加while判断的逻辑;

def get_factor(n):
    print ('{} = '.format(n), end=" ")
    if not isinstance(n, int) or n <= 0 :
        print ('请输入一个正确的数字 !')
        exit(0)
    elif n in [1] :
        print ('{}'.format(n))
    while n not in [1] : # 循环保证递归
        for a in range(2, n + 1) : 
            if n % a == 0: 
                n //= a    
                if n == 1:      # 这步很重要,判断关键 
                    print (a)
                else : # index 一定是素数
                    print ('{} *'.format(a), end=" ")
                break
get_factor(10) 


"""
题目15:利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60-89分之间的用B表示,60分以下的用C表示。
"""
def score(n):
    if n>=90:
        print("A")
    elif 60<n<=89:
        print("B")
    else:
        print("C")
score(90)


"""
题目16:输出指定格式的日期。
"""
和第10题一样,考验包的用法
import datetime
print(datetime.date.today()) 
print(datetime.date.today().strftime('%d/%m/%Y'))
print(datetime.date(1941, 1, 5))


"""
题目17:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。
"""
考察string包的用法, 举个例子: "kobe 8&24"
英文:4 数字:3  空格:1 其他字符:1
要自己写的话,逻辑写入0-9/大小写一致a-z/" "空格/其他 先定义; 

import string
def get_str(n):
    letters = 0
    space = 0
    digit = 0
    others = 0
    for a in n:
        if a.isalpha():     # 字母 
            letters += 1
        elif a.isspace():   # 空格
            space += 1
        elif a.isdigit():   # 数字
            digit += 1
        else:
            others += 1 
    print ('char = %d,space = %d,digit = %d,others = %d' % (letters,space,digit,others))

get_str("Kobe 8&24")

"""
题目18:求s=a+aa+aaa+aaaa+aa...a的值,其中a是一个数字。例如2+22+222+2222+22222(此时共有5个数相加),几个数相加由键盘控制.
""" 
分析:
传入2个参数 
1.总的几个数相加即最长的长度: len = 5 
2.传入的n 是什么:2 22 222 2222 22222 
找规律:
2 = 2*10**0      n = 2= (len-1) 
22 = 2*10**1+2
222 = 2*10**2 + 22
2222 = 2*10**3 + 222
得公式: tmp = n*10**(len-1) + tmp  

def get_sum(n,len):
    sum = 0   # 输出和 
    tmp = 0   # 分解的值 
    for a in range(1,len+1):  # a 浮标 = 幂  
        tmp = n*10**(a-1) + tmp  
        sum += tmp 
    return sum  
get_sum(2,5) 


"""
题目19:一个数如果恰好等于它的因子之和,这个数就称为"完数"。例如6=1+2+3.编程找出1000以内的所有完数。
""" 
分析:14先找因子  然后 n = sum(因子和)

for a in range(1, 1000):
    sum = 0
    for b in range(1, a):
        if a % b == 0:
            sum += b
    if sum == a:
        print(a)


"""
题目20:一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第10次落地时,共经过多少米?第10次反弹多高?
""" 
       落下高度 返回高度 落地时经过距离 
第一次   100     50     100 
第二次    50     25     100 + 100 = 200 
第三次    25     12.5   50  + 100 + 100 = 250 
第四次    12.5   6.25   25  + 100 + 100 +50 = 275  
可以看到规律  
第n次   分析找出规律即可  

def fall(n):
    height = 100
    far = 100
    for i in range(2, n+1):
        far = far + height
        height = height / 2
    return far,height/2
fall(10) 

"""
题目21:猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个.
       第二天早上又将剩下的桃子吃掉一半,又多吃了一个。
       以后每天早上都吃了前一天剩下的一半零一个。
       到第10天早上想再吃时,见只剩下一个桃子了。求第一天共摘了多少。
""" 
分析: 每次1/2+1,倒推即最后剩下的(n+1)*2 = n 前一天的
     即1 1534/2-1 = 766
       2 766/2-1 = 382 
       3 382/2-1 = 190
       4 190/2-1 = 94
       5 94/2 -1 = 46 
       6 46/2 -1 = 22 
       7 22/2 -1 = 10 
       8 10/2 -1 = 4 
       9 4/2  -1 = 1 
def peach(rest):
    rest = 1
    for a in range(1,11):  # 第10天剩1个,实际是第九天吃完后还剩1个  a = 循环天数
        if a <= 9: 
            rest = (rest+1)*2
            a = a + 1
        else:
            break 
    return rest 
peach(10)

"""
题目22:两个乒乓球队进行比赛,各出三人。甲队为a,b,c三人,乙队为x,y,z三人。已抽签决定比赛名单。有人向队员打听比赛的名单。
       a说他不和x比,c说他不和x,z比,请编程序找出三队赛手的名单。
""" 
分析: 直接可以得出答案,c和y, a和z,b和x ,用变成实现则将判断逻辑写下即可; 
for a in ['x','y','z']:
    for b in ['x', 'y', 'z']:
        for c in ['x', 'y', 'z']:
            if(a!=b)and(b!=c)and(c!=a) and (a!='x') and (c!='x') and (c!='z'):
                print('a和%s比赛,b和%s比赛,c和%s比赛' %(a,b,c))2: 
m=['a','b','c']
n=['x','y','z']
L=[]
for i in range(0,3):
    for j in range(0,3):
        L.append(m[i]+n[j])
L.remove('ax')   
L.remove('ay')
L.remove('by')
L.remove('bz')
L.remove('cx')
L.remove('cz')
print(L) 

"""
题目23:打印出如下图案(菱形):
   *
  ***
 *****
*******
 *****
  ***
   *
""" 
def pic(n):
    for i in range(0,n):
        a = abs(i - int(n/2))
        b = n - abs(i - int(n/2))
        print(" "*a+"*"*(b-a))
pic(7)

"""
题目24:有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13...求出这个数列的前20项之和。
""" 
分析:
2 3 5 8 13 21
1 2 3 5 8  1320项之和首先得得到第20个数是什么,然后每个数相加 

def add_sum(n):   # n第几个数
    a = 1    # 分母 
    b = 1    # 分子
    sum = 0  
    for i in range(1,n+1):
        a,b = b,a+b
        sum += b/a 
    return sum 
add_sum(20)  

"""
题目25:求1+2!+3!+...+20!的和。
""" 
分析:24题是累加的概念,这里是累乘 

def mul_sum(n):   # n第几个数
    sum = 0
    tmp = 1
    for x in range(1,n+1):  
        tmp *= x
        sum += tmp 
    return sum 
mul_sum(3) 

前25题是比较容易的,大家有什么疑问可以留言讨论。

题外话

希望本文有大家有帮助, 如有错误,欢迎指正。
转载请注明原文链接:
https://blog.csdn.net/weixin_41613094/article/details/122132033

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值