实验四函数与异常处理编程

Posted hegejiushishiwo

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了实验四函数与异常处理编程相关的知识,希望对你有一定的参考价值。

任务一

print(sum)
sum=42
print(sum)

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

sum = inc(7) + inc(7)
print(sum)

 

任务二

def func1(a,b,c,d,e,f):
    return [a,b,c,d,e,f]
def func2(a,b,c,*,d,e,f):
    return[a,b,c,d,e,f]
def func3(a,b,c,/,d,e,f):
    return [a,b,c,d,e,f]

print(func1(1,9,2,0,5,3))
print(func1(a=1,b=9,c=2,d=0,e=5,f=3))
print(func1(1,9,2,f=3,d=0,e=5))

print(func2(11,99,22,d=0,e=55,f=33))
print(func2(a=11,b=99,c=22,d=0,e=55,f=33))

print(func3(111,999,222,0,555,333))
print(func3(111,999,222,d=0,e=555,f=333))

 

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))

 

 

任务三

def solve(a,b,c):
    \'\'\'求解一元二次方程,返回方程的两个根

    :para:a,b,c:float 方程系数
    :return:tuple
    \'\'\'
    delta = b*b - 4*a*c
    delta_sqrt = abc(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()

 

任务四

def list_generator(a,b,c):
    ls = [a]
    while a<b:
        a = a+c
        ls.append(a)
    print(ls)

list_generator(-5,5,2)

 

 

任务五

def is_prime(n):
    import math
    m = 0
    for i in range(2, int(math.sqrt(n)) + 1):
        if n % i == 0:
            m += 1
        else:
            m += 0
    if m != 0:
        result = False
    else:
        result = True
    return result

for i in range(4,21,2):
    for j in range(2,i):
        if is_prime(j) == True:
            k = i - j
            if is_prime(k) == True:
                print(f\'i = j + k\')
                break

 

任务六

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

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

text = input(\'输入英文文本: \')

encoded_text = encoder(text)
print(\'编码后的文本: \', encoded_text)

decoded_text = decoder(encoded_text)
print(\'对编码后的文本解码: \', decoded_text)

 

 

任务七

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))

 

任务八

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\')

 

 

20192306 实验四 《数据结构与面向对象程序设计》实验报告

20192306 2020-2021-1 《数据结构与面向对象程序设计》实验四报告

课程:《程序设计与数据结构》
班级: 1923
姓名: 孙洪丽
学号: 20192306
实验教师:王志强
实验日期:2020年10月22日
必修/选修: 必修

1.实验内容

  • Java Socket编程
  1. 学习蓝墨云上教材《Java和Android编程》“第16章 输入/输出 ”和“第22章 网络”,学习JavaSocket编程
  2. 结对编程。结对伙伴A编写客户端SocketClient.java,结对伙伴B编写服务器端。
  3. 截图加学号水印上传蓝墨云,代码push到码云,并撰写实验报告。
  • Java和密码学
    参考 http://www.cnblogs.com/rocedu/p/6683948.html
    以结对的方式完成Java密码学相关内容的学习(帖子中所有代码和相关知识点需要学习)。提交学习成果码云链接和代表性成果截图,要有学号水印。
  • 编写有理数/复数计算器
    结对编程,结对伙伴A编写有理数计算器。结对伙伴B编写复数计算器。截图加水印上传蓝墨云,代码push码云。
  • 远程有理数计算器
    结对编程,结对伙伴B编程实现客户端,结对伙伴A实现服务器端。
    客户端通过键盘输入一个有理数计算的公式(例如:1/4 + 1/6 = ),并把该公式以字符串的形式发送给伙伴A(服务器端),服务器端根据字符串计算出结果为5/12,并把结果返回给客户端B,B收到结果后输出结果。截图加水印上传蓝墨云,代码push码云。
  • 远程复数计算器
    结对编程,结对伙伴A编程实现客户端,结果伙伴B实现服务器端。
    客户端通过键盘输入一个有理数计算的公式(例如:1/4 + 1/6 = ),并把该公式以字符串的形式发送给伙伴A(服务器端),服务器端根据字符串计算出结果为5/12,并把结果返回给客户端A,A收到结果后输出结果。截图加水印上传蓝墨云,代码push码云。
    注意实验四(4)和实验四(5),一个人不能仅实现客户端,必须实现一个客户端和服务器,否则两个实验均不得分!!!
  • 实验报告
    在规定时间前发表博客,标题“学号 实验四 《数据结构与面向对象程序设计》实验报告”

2.实验过程及结果

Java Socket编程

  • 编写服务器
    技术图片
  • 编写客户端
    技术图片

Java和密码学

  • Caesar
  1. 加密
    技术图片
    技术图片
  2. 解密
    技术图片
    技术图片
  • DES
  1. 编写并运行生成密钥代码
    技术图片
    技术图片
  2. 编写并运行加密器
    技术图片
  3. 使用密钥解密
    技术图片
  • RSA
  1. 生成公钥和私钥
    技术图片
  2. 利用公钥加密
    技术图片
  3. 利用私钥解密
    技术图片
  • 密钥共享
    (根据教程,自己分别建立A和B进行学习测试,并未结对)
  1. 创建DH公钥和私钥(两组,A和B)
    技术图片
    技术图片
    技术图片
    技术图片
  2. 共享密钥(两组,A和B)
    技术图片
    技术图片
    技术图片
    技术图片
    打印结果相等,运行成功。
  • MD5
    技术图片
    技术图片

编写复数计算器

技术图片
技术图片
技术图片

远程有理数计算器

  • 编写客户端
    技术图片

远程复数计算器

  • 编写服务器
    技术图片

3. 实验过程中遇到的问题和解决过程

  • 问题一:编写Socket时报错,即使是正确的网址,也显示找不到服务器网址;
    技术图片
  • 问题一解决:关闭电脑防火墙。
  • 问题二:测试教程上的Caesar密码时,运行后产生异常,显示数据溢出;
  • 问题二解决:配置参数,输入要加密的语句和密钥,再运行,这才是正确的加密运行方式(后面的加密也是)。

代码托管

(实验五配置码云时强制推送清空了仓库里的内容,所以原来有目录的码云托管链接失效了,改成了推送时生成的码链接,因云班课已提交过的活动超时后不可提交,所以链接无法更正)

其他(感悟、思考等)

  • 不能只依赖于教材和老师指定的学习链接,要多看博客,多学习,形成自己的学习方式。

参考资料














































以上是关于实验四函数与异常处理编程的主要内容,如果未能解决你的问题,请参考以下文章

实验四 函数与异常处理编程

实验四函数与异常处理编程

实验四 函数与异常处理编程

实验四 函数与异常处理编辑

实验4 函数与异常处理编程

实验4 函数与异常处理编程