第三章上机实践报告

1、实践的题目是:数字三角形.

2、问题的描述是:给定一个由 n行数字组成的数字三角形如下图所示:试设计一个算法,计算出从三角形 的

顶至底的一条路径(每一步可沿左斜线向下或右斜线向下),使该路径经过的数字总和最大。

3、算法的描述是:

for(i=n-1;i>=1;i--){

     for(j=0;j<i;j++){

         if(b[i][j]>b[i][j+1])

         b[i-1][j]=b[i][j]+a[i-1][j];

         else

         b[i-1][j]=b[i][j+1]+a[i-1][j];

}}

自下向上开始比较,选择大的数字。

4、算法时间及空间复杂度分析(需要有分析过程):

因为算法里有2重for循环,所以时间复杂度为n^2;申请了a、b两个数组,空间复杂度为n^2。

5、我的心得体会(对本次实践收获及疑惑进行总结):

在运行这题目的代码的时候总是出错,后来发现是因为最后输出的时候输出的是b[1][1]而不是b[0][0];因为忽视了这个小毛病而导致浪费了很多时间,以后对于问题的逻辑要更加严谨才可以。

转载于:https://www.cnblogs.com/anke-poi1234/p/10067660.html

很高兴为您提供 Python 第十一章上机实践。本章的实践内容主要是关于文件处理、异常处理和模块的使用。 1. 文件处理 第一道题目是要求读取一个文件并统计其中单词的数量。您可以按照以下步骤完成任务: (1)使用 open() 函数打开文件。 (2)使用 read() 函数读取文件内容。 (3)使用 split() 函数将文件内容按照空格分割成单词。 (4)使用 len() 函数统计单词数量。 下面是一个示例代码: ```python with open('file.txt', 'r') as f: content = f.read() words = content.split(' ') count = len(words) print(f'The file has {count} words.') ``` 2. 异常处理 第二道题目是要求编写一个函数,将两个数相除并返回结果。但如果除数为 0,则应该抛出一个 ZeroDivisionError 异常。您可以按照以下步骤完成任务: (1)定义一个函数。 (2)使用 if 语句判断除数是否为 0。 (3)如果除数为 0,则使用 raise 语句抛出一个 ZeroDivisionError 异常。 (4)如果除数不为 0,则返回两个数的商。 下面是一个示例代码: ```python def divide(num1, num2): if num2 == 0: raise ZeroDivisionError('division by zero') else: return num1 / num2 try: result = divide(10, 0) except ZeroDivisionError as e: print(e) ``` 3. 模块的使用 第三道题目是要求使用 Python 标准库中的 random 模块生成一个随机数。您可以按照以下步骤完成任务: (1)使用 import 语句导入 random 模块。 (2)使用 random 模块中的 randint() 函数生成一个随机数。 下面是一个示例代码: ```python import random num = random.randint(1, 100) print(f'The random number is {num}.') ``` 希望这些实践题可以帮助您更好地理解 Python 文件处理、异常处理和模块的使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值