• 博客园logo
  • 会员
  • 周边
  • 新闻
  • 博问
  • 闪存
  • 众包
  • 赞助商
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录

yunsir

  • 博客园
  • 联系
  • 订阅
  • 管理

公告

View Post

实验4

实验任务1

task1.py

print(sum)
sum = 42
print(sum)
def inc(n):
    sum = n+1
    print(sum)
    return sum
sum = inc(7) + inc(7)
print(sum)

答:不是同一个对象的名称。line1是内置作用域, line3,line11的sum是全局作用域,line7的sum是局部作用域。

实验任务2

task2_2.py

答:内置函数sorted()中参数reverse一定要用关键字传递。

task2_3.py

def func(a, b, c, /, *, d, e, f):
    return( [a,b,c,d,e,f] )
print(func(1,2,3,d=4,e=5,f=6))

task3.py

def solve(a, b, c):
    '''
    求解一元二次方程, 返回方程的两个根
    :para: a,b,c: float 方程系数
    :return: tuple
    '''
    delta = b*b - 4*a*c
    delta_sqrt = abs(delta)**0.5
    p1 = -b/2/a
    p2 = delta_sqrt/2/a
    if delta >= 0:
        root1 = p1 + p2
        root2 = p1 - p2
    else:
        root1 = complex(p1, p2)
        root2 = complex(p1, -p2)
    return root1, root2
print(solve.__doc__)
while True:
    try:
        t = input('输入一元二次方程系数a b c, 或者,输入#结束: ')
        if t == '#':
            print('结束计算,退出')
            break
        a, b, c = map(float, t.split())
        if a == 0:
            raise ValueError('a = 0, 不是一元二次方程')
    except ValueError as e:
        print(repr(e))
        print()
    except:
        print('有其它错误发生\n')
    else:
        root1, root2 = solve(a, b, c)
        print(f'root1 = {root1:.2f}, root2 = {root2:.2f}')
        print()

 task4.py

def list_generator(a,b,c=1):
    lst = []
    while a<=b:
        lst.append(a)
        a += c
    return lst

list1 = list_generator(-5, 5)
print(list1)
list2 = list_generator(-5, 5, 2)
print(list2)
list3 = list_generator(1, 5, 0.5)
print(list3)

 task5.py

def is_prime(n):
    if n == 2:
        return True
    elif n != 1:
        for i in range(2,n):
            if n == 2:
                return True
            elif n % i == 0:
                break
            else:
                return True

for i in range(2,20+1,2):
    flag = True
    for j in range(2, i):
        if is_prime(j) == True and is_prime(i - j) == True and flag == True:
            print(f'{i}={j}+{i-j}')
            flag = False

 task6.py

def encoder(text):
    new_text1 = ''
    for i in text:
        if 'a' <= i <='z':
            i = chr((ord(i)-97+5)%26 + 97)
            new_text1 += i
        elif 'A' <= i <= 'Z':
            i = chr((ord(i)-65+5)%26 + 65)
            new_text1 += i
        else:new_text1 += i
    return new_text1

def decoder(text):
    new_text2 = ''
    for i in text:
        if 'a' <= i <='z':
            i = chr((ord(i)-97-5)%26 + 97)
            new_text2 += i
        elif 'A' <= i <= 'Z':
            i = chr((ord(i)-65-5)%26 + 65)
            new_text2 += i
        else:new_text2 += i
    return new_text2

 task7.py

def collatz(n):
    lst = []
    lst.append(n)
    while n != 1:
        if n %2 == 0:
            n = n/2
            lst.append(int(n))
        else:
            n = n*3 +1
            lst.append(int(n))
    return lst
try:
    n = int(input('Enter a positive integer:'))
    if n <= 0:
        raise ValueError
except ValueError:
    print('Error: must be a positive integer')
else:
    print(collatz(n))

 task8.py

def func(n):
    if n == 0:
        return 0
    else:
        return 2*func(n-1) + 1

while True:
    x = input()
    if x == '#':
        print('计算结束')
        break
    n = int(x)
    ans = func(n)
    print(f'n = {n}, ans = {ans}')

 

posted on 2023-05-23 21:36  昀sir  阅读(17)  评论(0)    收藏  举报

刷新页面返回顶部
 
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3