python练习集100题(1-20)

题目1:有1、2、3、4四个数,能组成多少个互不相同且无重复的三位数?都是多少?

list_num=[1,2,3,4]
all_num=[]
for i in list_num:
    for j in list_num:
        for k in list_num :
            if (i!=j) and (i!=k) and (j!=k):
                num=i*100+j*10+k
                all_num.append(num)
print(all_num) 
print(‘A total of %d numbers.‘ %len(all_num))

题目2:企业发放的奖金根据利润提成。

低于或等于10万元时,奖金可提成10%;

高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提成7.5%;

20万到40万之间时,高于20万元的部分可提成5%;

40万到60万之间时,高于40万元的部分,可提成3%;

60万到100万之间时,高于60万的部分,可提成1.5%;

超过100万元的部分按1%提成;

从键盘输入当月利润,求应发奖金总数。

while True:
    num=input(‘请输入利润:‘).strip()
    if num.isdigit():
        pass
    else :
        print(‘输入的利润必须为数字‘) 
        continue
    num=int(num)    #转换为整数类型
    if num > 1000000 :
        profit = (num-1000000)*0.01 + 400000*0.015 + 200000 *0.03 + 200000*0.05 + 100000*0.075 + 100000*0.1
        break
    elif num > 600000 :
        profit = (num-400000)*0.015 + 200000 *0.03 + 200000*0.05 + 100000*0.075 + 100000*0.1 
        break
    elif num > 400000 :
        profit = (num-200000) *0.03 + 200000*0.05 + 100000*0.075 + 100000*0.1
        break
    elif num > 200000 :
        profit = (num-200000)*0.05 + 100000*0.075 + 100000*0.1
        break
    elif num > 100000 :
        profit = (num-100000)*0.075 + 100000*0.1
        break
    else :
        profit = num*0.1
        break
print(‘应发奖金总数为:%d‘ %profit)

题目3:一个整数,它加上100后是一个完全平方数。再加上168又是一个完全平方数,问该数是多少。

import math
int_num=0
while True:
    num1=math.sqrt(int_num+100)
    num2=math.sqrt(int_num+168)
    if num1==int(num1) and num2 == int(num2):
        break
    int_num += 1
print(‘该整数为 %d‘ %int_num)

题目4:输入某年某月某日,判断这一天是这一年的第几天。(格式 如:19870604)

from builtins import len
leap_year={‘01‘:31,‘02‘:29,‘03‘:31,‘04‘:30,‘05‘:31,‘06‘:30,
           ‘07‘:31,‘08‘:31,‘09‘:30,‘10‘:31,‘11‘:30,‘12‘:31}    #闰年每月最大天数
comm_year={‘01‘:31,‘02‘:28,‘03‘:31,‘04‘:30,‘05‘:31,‘06‘:30,
           ‘07‘:31,‘08‘:31,‘09‘:30,‘10‘:31,‘11‘:30,‘12‘:31}     #平年每月最大天数
while True:
    num = input(‘请输入日期,格式如19540105:‘)
    if num.isdigit() and len(num)==8 :                      
        pass
    else :
        print(‘格式错误,请重新输入‘)
        continue
    year_num=int(num[:4]) 
    month_num=num[4:6]
    day_num=int(num[6:])
    if (int(month_num)>12) or (int(month_num)<=0):     #月份错误时,重新输入,‘01‘字符串转换为整数时,会舍弃0,无法遍历字典
            print(‘月份输入错误,请重新输入。‘)
            continue
    days=0                                                       #定义天数
                                                        
    if ((year_num%100==0) and (year_num%400 == 0)) or ((year_num%100 !=0) and (year_num%4 == 0)):   #如果是闰年
        if (day_num > leap_year[month_num]) or (day_num <= 0): #日期错误时重新输入
            print(‘此月份中没有这一天,请重新输入。‘)
            continue
        for i in leap_year.keys():                               #遍历月份
            if int(i) < int(month_num):
                days = days + leap_year[i]
            elif int(i)==int(month_num):
                days = days + day_num
    else:                                                       #如果是平年
        if (day_num > comm_year[month_num]) or (day_num <= 0):  #日期错误时重新输入
            print(‘此月份中没有这一天,请重新输入。‘)
            continue
        for i in comm_year.keys():                               #遍历月份
            if int(i) < int(month_num):
                days = days + comm_year[i]
            elif int(i)==int(month_num):
                days = days + day_num
    print(‘这一天是今年的第 %d 天‘ %days)
    break

题目5:输入三个整数x,y,z,请把这三个数从小到大输出。

def isint(num):
    while True:
        a=input(‘请输入整数 %s:‘ %num).strip()
        if a.isdigit() :
            break
        else:
            print(‘ %s 不是整数,请重新输入‘ %a)
    return a
dic={}
dic[‘x‘]=isint(‘x‘)
dic[‘y‘]=isint(‘y‘)
dic[‘z‘]=isint(‘z‘)
dic=list(dic.values())
dic.sort()
print(dic)

题目6:用*输出字母c的图案。

list_c=[‘  **** ‘,‘ *    *‘,‘*‘,‘*‘,‘*‘,‘ *    *‘,‘  **** ‘]
for i in list_c:
    print(i)
    
输出结果:
  **** 
 *    *
*
*
*
 *    *
  ****

题目7:输出9*9口诀表。

for i in range(1,10):
    j=1
    while j<=i:
        print(‘%d*%d=%-2d ‘ % (j,i,(i*j)),end=‘‘)
        j +=1
    print(end=‘\n‘)
输出结果:
1*1=1  
1*2=2  2*2=4  
1*3=3  2*3=6  3*3=9  
1*4=4  2*4=8  3*4=12 4*4=16 
1*5=5  2*5=10 3*5=15 4*5=20 5*5=25 
1*6=6  2*6=12 3*6=18 4*6=24 5*6=30 6*6=36 
1*7=7  2*7=14 3*7=21 4*7=28 5*7=35 6*7=42 7*7=49 
1*8=8  2*8=16 3*8=24 4*8=32 5*8=40 6*8=48 7*8=56 8*8=64 
1*9=9  2*9=18 3*9=27 4*9=36 5*9=45 6*9=54 7*9=63 8*9=72 9*9=81

题目8:斐波那契数列。即:0,1,1,2,3,5,8,13。

数学定义:F0=0,F1=1,Fn=f(n-1)+F(n-2)

def fibonacci_sequence(n):
    if n==0:
        return 0
    elif n==1:
        return 1
    else:
        return fibonacci_sequence(n-1)+fibonacci_sequence(n-2)
num=int(input(‘请输入一个整数:‘))
for i in range(num):
    val=fibonacci_sequence(i)
    print(‘n=%d,Fn=%d ‘ %(i,val))
输出结果:
请输入一个整数:10
n=0,Fn=0 
n=1,Fn=1 
n=2,Fn=1 
n=3,Fn=2 
n=4,Fn=3 
n=5,Fn=5 
n=6,Fn=8 
n=7,Fn=13 
n=8,Fn=21 
n=9,Fn=34

题目9:输出国际象棋棋盘。

a=‘ ‘
for i in range(8):
    for j in range(8):
        if i%2==0:
            if j%2==0 :
                print(‘\033[7;37m%s\033[0m‘ %a,end=‘‘)
            else:
                print(‘\033[7;30m%s\033[0m‘ %a,end=‘‘)
        else:
            if j%2!=0 :
                print(‘\033[7;37m%s\033[0m‘ %a,end=‘‘)
            else:
                print(‘\033[7;30m%s\033[0m‘ %a,end=‘‘)
    print(end=‘\n‘)
输出结果:

题目10:古典问题,有一对兔子,从出生后第三个月起每个月都出生一对兔子,小兔子涨到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少。

def rabbit_num(n):
    if n==1:
        return 1
    elif n==2:
        return 1
    else:
        return rabbit_num(n-1)+rabbit_num(n-2)
num=int(input(‘请输入一个整数:‘))
for i in range(1,num+1):
    val=rabbit_num(i)
    print(‘n=%d,Fn=%d ‘ %(i,val))

题目11:判断101-200之间有多少个素数,并输出所有素数。

num=[]
for i in range(100,201):
    j=i//2              
    for k in range(2,j):
        if i%k==0:
            break
    else:
        num.append(i)
print(‘一共有%d个素数\n这些素数是:‘ %len(num),num )
输出结果:
一共有21个素数
这些素数是: [101, 103, 107, 109, 113, 127, 131, 137, 139, 149, 151, 157, 163, 167, 173, 179, 181, 191, 193, 197, 199]

题目12:打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数字本身。例如:153=1的三次方+5的三次方+3的三次方。

num=[]
def cubic_sum(n):
    return n*n*n
for i in range(100,1000):
    i_hun=i//100                  #百位
    i_ten=(i%100)//10             #十位
    i_bit=i-i_hun*100-i_ten*10    #个位
    i_sum=cubic_sum(i_bit)+cubic_sum(i_ten)+cubic_sum(i_hun)
    if i_sum==i:
        num.append(i)
print(num)
输出结果:
[153, 370, 371, 407]

题目13:讲一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。

num=[]                  #该数字的所有素数
fac_num=[]              #该数字的因数
def pri_num(val):       #求出该数字的所有素数
    for i in range(2,val):
        if i<=4:
            j=i
        else:
            j=i//2              
        for k in range(2,j):
            if i%k==0:
                break
        else:
            num.append(i)
def sol_factor(val,*k):   #求因数
    for i in k:           #遍历素数
        if val%i==0:
            return i
            break
input_num=int(input(‘请输入要分解的数:‘))
pri_num(input_num)               #求出该数字的所有素数
decom_num=input_num              #要分解的数
while True:
    res=sol_factor(decom_num,*num)
    if res==decom_num:           #遍历结束
        fac_num.append(str(res))
        break
    else:
        fac_num.append(str(res))
        decom_num= decom_num/res
print(input_num,‘=‘,‘*‘.join(fac_num))#分解后的表达式
输出结果:
  请输入要分解的数:180
  180 = 2*2*3*3*5
  请输入要分解的数:900
  900 = 2*2*3*3*5*5

题目14:利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60-89分之间的用B表示,60分以下的用C表示。

score=int(input(‘请输入分数:‘).strip())
if score < 0  or score>100:
    print(‘输入的分数不合理,请重新输入‘)
elif score >= 90:
    print(‘该同学得A‘) 
elif score >=60 and score<90:
    print(‘该同学得B‘)
else:
    print(‘该同学得C‘)

题目15:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。

input_str=input(‘请输入要统计的字符串:‘)
count_str={}
for i in input_str:
    if i in count_str:
        count_str[i] +=1
    else:
        count_str[i] =1
print(count_str)
输出结果:
  请输入要统计的字符串:kahgasodgh934q455t
{‘o‘: 1, ‘t‘: 1, ‘4‘: 2, ‘q‘: 1, ‘h‘: 2, ‘5‘: 2, ‘d‘: 1, ‘3‘: 1, ‘9‘: 1, ‘s‘: 1, ‘a‘: 2, ‘g‘: 2, ‘k‘: 1}

题目16:求s=a+aa+aaa+aaaa+aa..a的值,其中a是一个数字。例如:2+22+222+2222+22222(此时公有五个数相加),几个数相加由键盘控制。

def sum_num(num,dig_num):
    var=0
    for i in range(dig_num):
        var +=int((num*(i+1)))
        if i==(dig_num-1):
            print(int((num*(i+1))),end=‘=‘)   #整数乘字符  ,‘3‘*3=‘333‘
        else:
            print(int((num*(i+1))),end=‘+‘)
    return var
        
        
num=input(‘请输入要计算的数字:‘)         #字符类型
dig_num=int(input(‘请输入要计算的次数:‘))#整数类型
sum_dig=sum_num(num,dig_num)
print(sum_dig)
输出结果:
  请输入要计算的数字:1
  请输入要计算的次数:3
  1+11+111=123
  请输入要计算的数字:2
  请输入要计算的次数:5
  2+22+222+2222+22222=24690

题目17:一个数如果恰好等于它的因子之和,这个数成为“完数”、例如6=1+2+3.编写程序找出1000以内所有的完数。

def pri_num(val):          #求出该数字的所有素数
    for i in range(2,val+1):
        if i<=4:
            j=i
        else:
            j=i//2              
        for k in range(2,j):
            if i%k==0:
                break
        else:
            num.append(i)
def sol_factor(val,*k):    #求因数
    for i in k:             #遍历素数
        if val%i==0:
            return i
            break
    else:
        return 1
for input_num in range(2,1000):
    sum_num=1
    num=[]                  #该数字范围内的所有素数
    fac_num=[]              #该数字的因数
    pri_num(input_num)      #求出该数字的所有素数
    decom_num=input_num     #要分解的数
    while True:
        res=sol_factor(decom_num,*num)
        if res==decom_num:           #遍历结束
            sum_num +=res
            fac_num.append(str(res))
            break
        else:
            sum_num +=res
            fac_num.append(str(res))
            decom_num= decom_num/res
    if sum_num==input_num:
        print(input_num,‘=1+‘,‘+‘.join(fac_num)) #分解后的表达式
输出结果:
  6 =1+ 2+3

题目18:一个球从100米高度自由下落,每次落地后跳回原高度的一半;再落地,求它在第10次落地时,共经过过少米?第10次反弹多高?

high=100
sum_meter=0
for i in range(10):
    if i==0:        #第一次落地
        sum_meter +=high
        high /=2
    else:
        sum_meter += (2*high)
        high /=2
#     print(‘第%d次落地可以反弹的高度: %f‘ %((i+1),high))
#     print(‘第%d次落地经过了%f米‘ %((i+1),sum_meter))
print(‘----------------------------------‘)
print(‘第10次落地可以反弹的高度: %f米‘ %(high))
print(‘一共经过了%f米‘ %(sum_meter))
输出结果:
  第1次落地可以反弹的高度: 50.000000
  第1次落地经过了100.000000米
  第2次落地可以反弹的高度: 25.000000
  第2次落地经过了200.000000米
  第3次落地可以反弹的高度: 12.500000
  第3次落地经过了250.000000米
  第4次落地可以反弹的高度: 6.250000
  第4次落地经过了275.000000米
  第5次落地可以反弹的高度: 3.125000
  第5次落地经过了287.500000米
  第6次落地可以反弹的高度: 1.562500
  第6次落地经过了293.750000米
  第7次落地可以反弹的高度: 0.781250
  第7次落地经过了296.875000米
  第8次落地可以反弹的高度: 0.390625
  第8次落地经过了298.437500米
  第9次落地可以反弹的高度: 0.195312
  第9次落地经过了299.218750米
  第10次落地可以反弹的高度: 0.097656
  第10次落地经过了299.609375米
  ----------------------------------
  第10次落地可以反弹的高度: 0.097656米
  一共经过了299.609375米

题目19:求1+2!+3!+4!+...20!的和。

def factorial_sum(num):
    if num==1:
        return 1
    else:
        return num*factorial_sum(num-1)
res=0
for i in range(1,21):
    res +=factorial_sum(i)
    if i ==20 :
        print(i,end=‘!=‘)
    else :
        print(i,end=‘!+‘)
print(res)   
输出结果:
  1!+2!+3!+4!+5!+6!+7!+8!+9!+10!+11!+12!+13!+14!+15!+16!+17!+18!+19!+20!=2561327494111820313

题目20:猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾又多吃了一个;第二天早上又将剩下的桃子吃掉一半,又多吃了一个;以后每天早上都吃前一天剩下的一半多一个。到第十天早上想吃桃子时,只剩下了一个。求第一天共摘了多少。

peach_num=0   #可以整除2,一定是偶数个桃子
Flages=True
while Flages:
    peach_num +=2
    temp=peach_num
    for i in range(3):         #遍历次数,检验
        temp=temp/2
        if temp==int(temp): #当中有一次无法整除就退出
            temp -=1
            if temp==0:        #不能为0
                break
        else:
            break
    else:
        if temp==1:
            Flages = False
print(‘第一天摘了%d个桃子‘ %peach_num)
输出结果:
  假设第二天只剩一个桃子时:第一天摘了4个桃子。
  假设第三天只剩一个桃子时:第一天摘了10个桃子.
  假设第四天只剩一个桃子时:第一天摘了22个桃子.
  假设第五天只剩一个桃子时:第一天摘了46个桃子.
  ...
  假设第十天只剩一个桃子时:第一天摘了1534个桃子.
时间: 2024-10-12 09:14:06

python练习集100题(1-20)的相关文章

python练习集100题(21-40)

题目21:两个乒乓球队进行比赛,各出3人.甲队为a,b,c三人,乙队为x,y,z三人.以抽签决定比赛名单.有人向队员打听比赛的名单.a说他不和x比,c说他不和x.z比,请编程找出三队比赛名单. first_list=['x','y','z'] for i in first_list:        #i是a的对手,j是b的对手,k是c的对手     for j in first_list:         if(j!=i):                        for k in fir

python面试的100题(21)

正则表达式 94.请写出一段代码用正则匹配出ip? ip地址的生成规则. IP地址,是由32位数字二进制转为四个十进制的字符串组成. 怎么转化?下面讲解: 二进制:11111111111111111111111111111111 分为四部分:11111111.11111111.11111111.11111111 转化:2^7+2^6+2^5+2^4+2^3+2^2+2^1+2^0=255 转为十进制范围:0~255.0~255.0~255.0~255 这就是IP地址的范围. 根据这个生成IP的规

python自测100题,来看看你和月薪3万的差距(含答案)

-------------人生苦短,必须性感! 1.为什么学习Python? 人生苦短?人间不值得?想想自己的初心吧! 2.通过什么途径学习的Python? 官网.网上视频.学习网站.论坛.大牛的辅导 3.Python和Java.PHP.C.C#.C++等其他语言的对比? (1).python代码,简介,明确,优雅,简单易懂(2).开发效率高(3).可扩展性强 4.简述解释型和编译型编程语言? 解释型:在执行程序时,计算机才一条一条的将代码解释成机器语言给计算机来执行编译型:是把源程序的每一条语

Java重写《C经典100题》 --20

[程序20] 题目:一球从100米高度自由落下,每次落地后反跳回原高度的一半:再落下,求它在第10次落地时,共经过多少米?第10次反弹多高? 1.程序分析:除第一次以外每次落地经过的距离都是落地距离的两倍(弹起,落下),下一次是这个距离的1/2. 2.程序源代码: 1 /*本文转自博客:www.cnblogs.com/java-100 2 [程序20] 3 题目:一球从100米高度自由落下,每次落地后反跳回原高度的一半:再落下,求它在第10次落地时,共经过多少米?第10次反弹多高? 4 程序分析

python面试的100题(9)

17.python如何实现单例模式?请写出两种实现方式? 第一种方法:使用装饰器 def singleton(cls): instances = {} def wrapper(*args, **kwargs): if cls not in instances: instances[cls] = cls(*args, **kwargs) return instances[cls] return wrapper @singleton class Foo(object): pass foo1 = Fo

python面试的100题(15)

41.super函数的具体用法和场景 为了调用父类(超类)的一个方法,可以使用 super() 函数,比如: class A: def spam(self): print('A.spam') class B(A): def spam(self): print('B.spam') super().spam() # Call parent spam() super() 函数的一个常见用法是在 __init__() 方法中确保父类被正确的初始化了: class A: def __init__(self

python面试的100题(18)

函数 52.python常见的列表推导式? 列表推导式书写形式: [表达式 for 变量 in 列表] 或者 [表达式 for 变量 in 列表 if 条件] 参考地址:https://www.cnblogs.com/yupeng/p/3428556.html 53.简述read.readline.readlines的区别? (1) read(size):按字节从头读到最后,返回的是一个字符串类型,其中参数size是表示读取的字节数,size的默认是读取全部. (2) readline() :每

python面试的100题(7)

8.将字符串 "k:1 |k1:2|k2:3|k3:4",处理成字典 {k:1,k1:2,...} str1 = "k:1|k1:2|k2:3|k3:4" def str2dict(str1): dict1 = {} for iterms in str1.split('|'): key,value = iterms.split(':') dict1[key] = value return dict1 #字典推导式 d = {k:int(v) for t in str

LeetCode面试常见100题( TOP 100 Liked Questions)

LeetCode面试常见100题( TOP 100 Liked Questions) 置顶 2018年07月16日 11:25:22 lanyu_01 阅读数 9704更多 分类专栏: 面试编程题真题合集 常见算法问题 LeetCode试题 LeetCode常见试题 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/lanyu_01/article/details/81062232 这篇文章