python练题(自用)

企业发放的奖金根据利润提成。利润(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,求应发放奖金总数?

i=int(input())
arr=[1000000,600000,400000,200000,100000,0]
brr=[0.01,0.015,0.03,0.05,0.075,0.1]
w=0
for j in range(0,6):
    if i>arr[j]:
        w+=(i-arr[j])*brr[j]
        i=arr[j]
print(w)

一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?

假设该数为 x。

1、则:x + 100 = n2, x + 100 + 168 = m2

2、计算等式:m2 - n2 = (m + n)(m - n) = 168

3、设置: m + n = i,m - n = j,i * j =168,i 和 j 至少一个是偶数

4、可得: m = (i + j) / 2, n = (i - j) / 2,i 和 j 要么都是偶数,要么都是奇数。

5、从 3 和 4 推导可知道,i 与 j 均是大于等于 2 的偶数。

6、由于 i * j = 168, j>=2,则 1 < i < 168 / 2 + 1。

7、接下来将 i 的所有数字循环计算即可。


for i in range(1,85):
    if 168%i==0:
        j=168/i
        if i > j and (i + j) % 2 == 0 and (i - j) % 2 == 0 :
            m=(i+j)/2
            n=(i-j)/2
            x=n*n-100
            print(x)

 

输入某年某月某日,判断这一天是这一年的第几天?

year=int(input())
month=int(input())
day=int(input())

months = (0,31,59,90,120,151,181,212,243,273,304,334)
if 0<=month<13:
    sum=months[month-1]
else:
    print("data error")
sum+=day
flag=0
if (year%4==0) or (year%400==0) and (year%100!=0):
    flag=1
if(flag==1) and (month>2):
    sum+=1
print("%d"%sum)

输入三个整数x,y,z,请把这三个数由小到大输出。

#法一
x=int(input('x='))
y=int(input('y='))
z=int(input('z='))
if x>y:
    x,y=y,x
if x>z:
    x,z=z,x
if y>z:
    y,z=z,y
print(x,y,z)

#法二
l=[]
for i in range(0,3):
    x=int(input())
    l.append(x)
l.sort()
str=" ".join('%s' %id for id in l) #将列表转化为字符串
print(str)

斐波那契数列

#法一
def fib(n):
    a,b=1,1
    for i in range(n-1):
        a,b=b,b+a
    return a

print(fib(10))

#法二
def fib(n):
    if n==1 or n==2:
        return 1
    return fib(n-1)+fib(n-2)

print(fib(10))

#法三
def fib(n):
    if n==1:
        return [1]
    if n==2:
        return [1,1]
    fibs=[1,1]
    for i in range(2,n):
        fibs.append(fibs[-1]+fibs[-2])
    return fibs

print(fib(10))

将一个列表的数据复制到另一个列表中

a=[1,2,3]
b=a[:]
print(b) #不论a中间有几个空格,b一直为[1, 2, 3]

输出 9*9 乘法口诀表

for i in range(1,10):
    print()
    for j in range(1,i+1):
        print("%d*%d=%d"%(i,j,i*j),end=' ')

暂停一秒输出

time.sleep(1)

格式化当前时间

time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time()))
#输出 2015-10-21 17:48:40

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

f1=1
f2=1
for i in range(1,22):
    print("%12ld%12ld"%(f1,f2),end='')
    if(i%3==0):
        print()
    f1=f1+f2
    f2=f1+f2
#           1           1            2           3            5           8 
#          13          21           34          55           89         144 
#         233         377          610         987         1597        2584 
#        4181        6765        10946       17711        28657       46368 
#       75025      121393       196418      317811       514229      832040 
#     1346269     2178309      3524578     5702887      9227465    14930352 
#    24157817    39088169     63245986   102334155    165580141   267914296 

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

#法一
def ss(n):
    for i in range(2,n):
        if(n%i==0):
            return 0
    else: #注意此处缩进
        return 1
n=0
for i in range(101,201):
    if(ss(i)!=0):
        n+=1
        print(i)
print(n)

#法二
h=0
leap=1
from math import sqrt

for i in range(101,201):
    k=int(sqrt(i+1))
    for j in range(2,k+1):
        if(i%j==0):
            leap=0
            break
    if leap==1:
        print('%d'%i)
        h+=1
    leap=1
print(h)

获取 100 以内的质数

num=[]
for i in range(2,100):
   for j in range(2,i):
      if(i%j==0):
         break
   else:
      num.append(i)
print(num)

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

#法一
for i in range(1,10):
    for j in range(0,10):
        for k in range(0,10):
            x=i*100+j*10+k
            if(i**3+j**3+k**3==x):
                print(x)

#法二
for n in range(100,1000):
    i = n // 100
    j = n // 10 % 10
    k = n % 10
    if n == i*i*i + j*j*j + k*k*k: 
        print(n)

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

def reduceNum(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 i in range(2, n + 1):
            if n % i == 0:
                n //= i
                if n == 1:
                    print(i)
                else:  # i 一定是素数
                    print('{} *'.format(i), end=" ")
                break

reduceNum(90)

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

程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:
(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。
(2)如果n<>k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,重复执行第一步。
(3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。

def reduceNum(n):
    print("{} = ".format(n),end='')
    if(isinstance(n,int)==False) or (n<=0): #if not isinstance(n, int) or n <= 0 :
        print("data error")
        exit(0) #完全退出程序
    elif(n==1):
        print('{}'.format(n))
    while n not in [1]:  # 循环保证递归
        for i in range(2,n+1):
            if(n%i==0):
                n//=i
                if(n==1):
                    print(i)
                else:  # i 一定是素数
                    print('{} *'.format(i), end=" ")
                break
reduceNum(90)

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

n=input()
letters=0
space=0
digit=0
others=0
for c in n:  #注意循环
    if c.isalpha():
        letters+=1
    elif c.isdigit():
        digit+=1
    elif c.isspace():
        space+=1
    else:
        others+=1
print("%d %d %d %d"%(letters,space,digit,others))

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

from functools import reduce

Tn = 0
Sn = []
n = int(input('n = '))
a = int(input('a = '))
for count in range(n):
    Tn = Tn + a
    a = a * 10
    Sn.append(Tn)
    print(Tn)

Sn = reduce(lambda x, y: x + y, Sn) #计算列表之和
print("计算和为:", Sn)

一个数如果恰好等于它的因子之和,这个数就称为"完数"。例如6=1+2+3.编程找出1000以内的所有完数。

#法一
from functools import reduce
def zhiyinshu(n):
    l=[1]
    if(n!=1):
        for i in range(2,n):
            if(n%i==0):
                l.append(i)
    x = reduce(lambda x, y: x + y, l)
    return x

for i in range(2,1001):
    if(i==zhiyinshu(i)):
        print(i)

#法二
for j in range(2, 1001):
    k = []
    n = -1
    s = j
    for i in range(1, j):
        if j % i == 0:
            n += 1
            s -= i
            k.append(i)
    if s == 0:
        print(j)
        for i in range(n+1):
            print(str(k[i]),end=' ')
        print()

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

h=100
l=[100]
l2=[]
for i in range(0,9):
    h=h/2
    l.append(2*h)
    l2.append(h)
print(sum(l))
print('{}'.format(l2[-1]))

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

x=1
for i in range(0,9):
    x=(x+1)*2
print(x)
两个乒乓球队进行比赛,各出三人。甲队为a,b,c三人,乙队为x,y,z三人。已抽签决定比赛名单。有人向队员打听比赛的名单。a说他不和x比,c说他不和x,z比,请编程序找出三队赛手的名单。
for i in range(ord('x'),ord('z')+1):
    for j in range(ord('x'),ord('z')+1):
        for k in range(ord('x'),ord('z')+1):
            if(i!=j) and (j!=k) and (i!=k):
                if(i!=ord('x')) and (k!=ord('x')) and (k!=ord('z')):
                    print("a--%c b--%c c--%c"%(chr(i),chr(j),chr(k)))

打印出如下图案(菱形):

   *
  ***
 *****
*******
 *****
  ***
   *
#from sys import stdout
for i in range(4):
    for j in range(3-i):
        print(" ",end='') #等价于stdout.write(' ')
    for k in range(2*i+1):
        print("*",end='')
    print()
for i in range(3):
    for j in range(i+1):
        print(" ",end='')
    for k in range(5-2*i):
        print("*",end='')
    print()

有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13...求出这个数列的前20项之和。

#法一
sum=0
a,b=2,1
for i in range(0,20):
    sum+=a/b
    a,b=a+b,a
print(sum)

#法二
from functools import reduce
 
a = 2.0
b = 1.0
l = []
l.append(a / b)
for n in range(1,20):
    b,a = a,a + b
    l.append(a / b)
print (reduce(lambda x,y: x + y,l))

求1+2!+3!+...+20!的和。

#法一
n = 0
s = 0
t = 1
for n in range(1,21):
    t *= n
    s += t
print ('1! + 2! + 3! + ... + 20! = %d' % s)

#法二
s = 0
l = range(1,21)
def op(x):
    r = 1
    for i in range(1,x + 1):
        r *= i
    return r
s = sum(map(op,l))
print ('1! + 2! + 3! + ... + 20! = %d' % s)

利用递归方法求5!

def fact(j):
    sum = 0
    if j == 0:
        sum = 1
    else:
        sum = j * fact(j - 1)
    return sum
 
print (fact(5))

利用递归函数调用方式,将所输入的5个字符,以相反顺序打印出来

def output(s,l):
    if l==0:
       return
    print (s[l-1])
    output(s,l-1)

s = input('Input a string:')
l = len(s)
output(s,l)

给一个不多于5位的正整数,要求:一、求它是几位数,二、逆序打印出各位数字。

x = int(input("请输入一个数:\n"))
a = x // 10000
b = x % 10000 // 1000
c = x % 1000 // 100
d = x % 100 // 10
e = x % 10
 
if a != 0:
    print ("5 位数:",e,d,c,b,a)
elif b != 0:
    print ("4 位数:",e,d,c,b)
elif c != 0:
    print ("3 位数:",e,d,c)
elif d != 0:
    print ("2 位数:",e,d)
else:
    print ("1 位数:",e)

一个5位数,判断它是不是回文数。即12321是回文数,个位与万位相同,十位与千位相同

a = int(input("请输入一个数字:\n"))
x = str(a)
flag = True
 
for i in range(len(x)//2):
    if x[i] != x[-i - 1]:
        flag = False
        break
if flag:
    print ("%d 是一个回文数!" % a)
else:
    print ("%d 不是一个回文数!" % a)

按相反的顺序输出列表的值

a = ['one', 'two', 'three']
for i in a[::-1]: #[:-1]去掉最后一个元素 [::-1]将所有元素逆序
    print (i)

按逗号分隔列表

L = [1,2,3,4,5]
s1 = ','.join(str(n) for n in L)
print (s1)

最大公约数与最小公倍数

def gongyue(a,b):
    while(b!=0):
        temp=a%b
        a,b=b,temp
    return a

def gongbei(a, b):
    return a * b / gongyue(a, b)

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值