python作业

这里写自定义目录标题

python简单程序

1.九九乘法表

for i in range(0,10):
    for j in range(0,i+1):
        print('{}x{}={}\t'.format(i,j,i*j),end='')
    print()

2.求1-2+3-4+5 … 99的所有数的和

sum = 0
for i in range(0,100):
    if i%2 == 1:
        sum += i
    else:
        sum -=i
print(sum)

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

s = input('输入字符:')
alpha = 0
num = 0
space = 0
other = 0
for i in s:
    if i.isalpha():
        alpha +=1
    elif i.isnumeric():
        num +=1
    elif i.isspace():
        space +=1
    else:
        other +=1
print('字母={},数字={},空格={},其他={}'.format(alpha,num,space,other))

4.python求阶乘之和,1!+2!+3!+…+n!

#定义递归函数实现阶乘功能
def recursion(s):
    if s == 1:
        return 1
    else:
        return s*recursion(s-1)
#进行求和
n = int(input('输入数字='))
sum = 0
for i in range(1,n+1):
    sum += recursion(i)
print(sum)

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

def nRepeatedNum():

    a = []
    for i in range(1,5):
        for j in range(1,5):
            for k in range(1,5):
                num = 100*i + 10*j + k
                if i!=j and j!=k and i!=k and num not in a:
                    a.append(num)
    print(len(a),a)
nRepeatedNum()

#方法二  使用itertools函数
def nRepeatedNum():
import itertools
temp_arr = list(itertools.permutations([1, 2, 3, 4], 3)) # 排列  # A_4^3 = (4)!/(4-3)! = (4*3*2*1)/1 = 24
arr = [100*t[0]+10*t[1]+t[2] for t in temp_arr]
print(len(arr),arr)

6.奖金问题


'''
题目:企业发放的奖金根据利润(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,求应发放奖金总数?
...

money = int(input("利润I:"))

arr = [1000000,600000,400000,200000,100000,0]
rat = [0.01,0.015,0.03,0.05,0.075,0.1]
bonus = 0
for i in range(len(arr)):
    if money > arr[i]:
        bonus += (money-arr[i])*rat[i]
        money = arr[i]
print(bonus)

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

import math

for i in range(-100,1000):
    m = math.sqrt(i+100)
    n = math.sqrt(i+100+168)
    if m%1 == 0 and n%1 ==0:
        print(i)


#如果不想使用开方函数,也可以使用Xueyang_Liu的方法也行。根据之前的推论x<=83.5,所以实际取值范围可以写成x<84。
arr=[]
result=[]
for i in range(84):
    arr+=[i**2]
for elem in arr:
    if elem+168 in arr:
            result+=[elem-100]
print(result)

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

'''
    【个人备注】:知道python有时间元组这一概念,这道题完全不需要计算。
    时间元组包含九个属性
    tm_year     年
    tm_mon      月(1~12)
    tm_mday     日(1~31)
    tm_hour     时(0~23)
    tm_min      分(0~59)
    tm_sec      秒(0~61, 60或61是闰秒)
    tm_wday     星期(0~6, 0是周一)
    tm_yday     第几天(1~366, 366是闰年)
    tm_isdst    夏令时(1夏令时、0非夏令时、-1代表未知。平时写代码基本用不到。夏时令是指部分国家地区,夏季人为将时间调快一小时,早睡早起,以便充分利用夏日光照,节约用电。中国从1992年起就没有再执行过这个了)
    '''
    import time
    date = input('输入时间(例如2018-01-23):')
    st = time.strptime(date,'%Y-%m-%d') # 时间文本转化成时间元祖
    num = st.tm_yday
    print(num)

9.斐波那契数列

#按照分割的方式,每次取列表后两项,然后相加
l = [0,1]
for i in range(10):
    arr = l[-2:]
    l.append(arr[0]+arr[1])
print(l)

10.打印出所有的"水仙花数

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

for i in range (100,1000):
    a = i//100
    b = i%100//10
    c = i%10
    if i == a**3 + b**3 +c**3:
        print(i)

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

import math
num = int(input('输入整数:'))
arr = []
while num > 1 :
    for i in range(2,int(math.sqrt(num))+1):
        if num%i == 0:
            arr.append(i)
            num = num//i
            break
    else:
        arr.append(num)
        break
print(arr)

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

'''
2+22+222+2222+22222
可以理解为:
20000 + 2*2000 + 3*200 + 4*20 + 5*2
也就是:
1*2*10^4 + 2*2*10^3 + 3*2*10^2 + 4*2*10^1 + 5*2*10^0
'''
a = int(input('输入数字:'))
t = int(input('输入个数:'))
num = 0

for i in range(1,t+1):
    num += i*2*(10**(t-i))
print(num)

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

for num in range(1,1000):
    arr = []
    for i in range(1,num):
        if num%i ==0:
            arr.append(i)
    if sum(arr) == num:
        print(num,arr)

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

total = 0
m = 100  # 第一次落地,经过了一百米
total += m
for i in range(10 - 1):  # 之后9次弹起到落地
    m = m / 2  # 弹起的高度
    total += 2 * m  # 弹起然后重新落地,一共经过的距离
print(total)
print(m / 2)

15.乒乓球比赛问题

'''
两个乒乓球队进行比赛,各出三人。
甲队为a,b,c三人,乙队为x,y,z三人。
已抽签决定比赛名单。有人向队员打听比赛的名单。
a说他不和x比,c说他不和x,z比,请编程序找出三队赛手的名单。
'''
import itertools
jia = ['a','b','c']
yi = ['x','y','z']
arr = list (itertools.permutations(yi,3))
arr = [[jia[i]+a[i] for i in range(3)] for a in arr]
for i in arr:
    if 'ax' in i:
        pass
    elif 'cx' in i or 'cz' in i :
        pass
    else:
        print(i)


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:
                if a!='x' and c!='x'and c!= 'z':
                    print('a'+a,'b'+b,'c'+c)

16.集合交并差集

# 可迭代变量转换为集合形式
    x = set('runoob')
    y = set('google')
    print(x, y)          # 重复的被删除 {'n', 'o', 'b', 'u', 'r'} {'o', 'g', 'e', 'l'}
    # 集合的交集、并集、差集
    print(x & y)         # 交集 {'o'}
    print(x | y)         # 并集 {'e', 'o', 'g', 'l', 'u', 'n', 'b', 'r'}
    print(x - y)         # 差集 {'n', 'b', 'u', 'r'}
    # 当然也可以写成函数形式,不过确实没有上面符号好记。
    print(x.intersection(y))
    print(x.union(y))
    print(x.difference(y))

17.取一个整数a从右端开始的4-7位

#取一个整数a从右端开始的4-7位
a = 123456789
b = str(a)
print(b[-7:-3])

18.打印出杨辉三角形(要求打印出10行)

arr = [1]
print(1)
while len(arr) < 10:  # [1,1]
    a = [0] + arr  # [0,1,1]
    b = arr + [0]  # [1,1,0]
    arr = [a[i] + b[i] for i in range(len(a))]  # [1,2,1]
    s = [str(i) for i in arr]
    print(' '.join(s))

19.有n个人围成一圈,顺序排号。 从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。

n = 34
arr = list(range(1,n+1))            # 所有人门外站成一队【a】,进门后依旧按序站好【b】
count,a,b = 0,arr,[]
# 开始解题
while len(a+b)>1:                   # 循环直到只剩1人
    num,count=a.pop(0),count+1      # 排队进门,每进一人【a.pop】,按一下计数器
    if count%3!=0:b.append(num)     # 进门后依旧按序站好【b.append】,计数器逢3淘汰。
    if a==[]:a,b=b,[]               # 如果门外没人了【a=[]】,所有人重新到门外站好【a=b】
print(a[0])

20.输入数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。

a = [6,3,10,2,5,1,4,7,9,8]
i = a.index(max(a))
a[0],a[i] = a[i],a[0]
i = a.index(min(a))
a[-1],a[i] = a[i],a[-1]
print(a)
  • 4
    点赞
  • 54
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值