【对算法期中卷子的解析和反思】

一、程序阅读并回答问题(共30分)

  1. #include<cstdio>
  2. #include<cstring>
  3. #include<iostream>
  4. using namespace std;
  5. char chess[10][10];
  6. int sign[10];
  7. int n, k, ans;
  8. void dfs(int x, int k)
  9. {
  10.   if (k == 0){
  11. ans++;
  12. return;
  13.     }
  14.    if (x+k-1 > n)
  15. return;
  16.   for (int i = x; i <= n; i++)
  17.       for (int j = 1; j <= n; j++)
  18.   if (!sign[j] && chess[i][j] == '#'){
  19. sign[j] = 1;
  20. dfs(i + 1, k - 1);
  21. sign[j] = 0;
  22. }
  23.  }
  24. int main()
  25. {
  26.     while (cin >> n >> k){
  27. memset(chess, 0, sizeof(chess));
  28. memset(sign, 0, sizeof(sign));
  29. if (n == -1 || k == -1)
  30. break;
  31.        for (int i = 1; i <= n; i++)
  32. for (int j = 1; j <= n; j++)
  33. cin >> chess[i][j];
  34. ans = 0;
  35. dfs(1, k);
  36. cout << ans << endl;
  37.      }
  38.    return 0;
  39.  }

设程序的输入如下,请写出程序执行到35行时变量chess的值。(3分)

4 4

...#

..#.

.#..

#...

-1 -1

这里的坑点就是chess[][]的范围是[0-9][0-9],很多人没考虑多余的部分

chess[1][1]~Chess[1][4]的值分别为“.”,“.”,“.”,“#”。

chess[2][1]~Chess[2][4]的值分别为“.”,“.”,“#”,“.”。

chess[3][1]~Chess[3][4]的值分别为“.”,“#”,“.”,“.”。

chess[4][1]~chess[4][4]的值分别为“#”,“.”,“.”,“.”。

其余值为0。

分析函数dfs(.)的时间复杂度,写出分析求解过程。(12分)

这个时间复杂度也是,跟之前的答案出来的还不一样,逆天

以前这个,纯纯数学公式推出来的,啥初始条件都是浮云

你想想,右边是组合数,我们可以理解为n列中选K列,再粗略的n行选、n-1行选......左边也该是个阶乘来着......无语

现在这个

若采用问题(1)中的输入,分析该程序的求解过程。(15分)

这个跟老师之前出的类似题写的真不一样,服了。

我觉得我这个写的是对的

二、算法分析题 (共40分)

某班级的同学正在玩一个游戏。他们在某个时刻把一个物品摆放到跑道的某个位置,设跑道的长度为10米且是笔直的。游戏前他们会把每个物品的价格,物品出现的时间和位置告诉给玩游戏的同学。假设玩游戏的同学刚开始时站在跑道的某个位置,他每秒跑的距离不超过1米。当然他可以不跑,也可以朝前或者朝后跑。他每跑到一个位置便可以快速的拾取该物品,然后以同样的速度跑到下一个位置。请问,他最多能够获得的物品的总价格是多少?

输入:

输入数据的第一行包含两个正整数n(0<n<100)和m(0<=m<=10),其中n表示待摆放的物品的个数,m表示刚开始时玩游戏同学所在的位置;在接下来的n行中,每行有3个整数x, t(0<T< 100000)和p,表示在第t秒会在x位置上摆放一个价值为p的物品。同一时刻可能在同一位置摆放多个物品。

输出:

玩游戏的同学最多能够拾取的物品的总价格是多少?

样例输入:

  4 4

  2 1 1

  3 2 5

  5 3 1

  6 2 3

样例输出:

  5  

要求:

请写出采用穷举法求解该问题的伪代码,并画出样例输入时的解空间树。(10分)

我们的算法的起点都不一样,真不知道这咋整

请写出采用动态规划算法求解上述问题的伪代码,并用样例输入对其进行验证,写出求解过程。(20分)

也是算法不一样

【拾取问题】-CSDN博客

好吧,老师写的比我好,我需要递归,他不用,但是这个有点颠覆我的思维,我没看懂

行号

执行次数

i

j

dp[i][j]

mValue

6

1

0

1

0

0

6

2

0

2

0

0

6

3

0

3

0

0

6

5

1

2

0

0

4

15

4

3

5

0

10

1

-

-

-

5

我也可以给这个表格,但是定义都不一样,咋能指望一模一样

表3 动态规划求解结果(dp[i][j])

(j,i)

0

1

2

3

4

5

6

7

8

9

10

0

0

0

0

0

0

0

0

0

0

0

0

1

0

0

0

0

0

0

0

0

0

0

0

2

0

0

0

5

0

0

3

0

0

0

0

3

0

0

5

5

5

4

3

3

0

0

0

分析(1)中算法的时间复杂度,写出分析求解过程。(10分)

没看懂咋分析的

题(1)为三叉树,深度为lTime+1,因此T(0)=3T(1),T(lTime)=O(1),其时间复杂度为O(3lTime)。

三、算法设计及实现(共30分)

有一个2*n大小的矩形地板,用2*2和2*1大小的瓷砖方块来填满它。求一共有多少种不同的放法?如下所示:

输入:

    输入包含若干行,每一行包含一个整数n(0<=n<=250),表示矩形地板的长度。

输出:

    对于每一行的输出,输出一行整数,表示矩形地板的不同的摆放方法。

样例输入:

2

8

12

100

200

样例输出:

  3

171

2731

845100400152152934331135470251

1071292029505993517027974728227441735014801995855195223534251

要求:

当n=2时,画出不同的摆放方法。(5分)

三种,略

假设长度为n时摆放两种砖块的不同摆放方法有f(n)种。如果前面两块摆放2*2的砖块,则剩余的n-2块砖块摆放两种不同砖块的摆放方法有多少种?(5分)

这里竟然是把f[n]当作函数,估计是老师像让我们用动态规划做,所以提示,答案是f[n-2]

假设长度为n时摆放两种砖块的不同摆放方法有f(n)种。如果前面1块摆放2*1的砖块,则剩余的n-1块砖块摆放两种不同的砖块总共有多少种不同的摆放方法?(5分)

f[n-1]

按题目要求编写完整程序,并简要说明算法求解思想。(15分)

【地板拼接问题】-CSDN博客

该算法的求解思想:

假设地板长度为n,有f[n]种放置2*1和2*2砖块的方法。假设某一块放2*2,则有方法数f[n-2];假设某一块竖着放2*1,则有方法数f[n-1];假设某一块横着放2*1,则有方法数f[n-2],因此得出转移方程f[n] = 2 * f[n-2] + f[n-1]

于是将求解dp[n]的问题,转化为求解dp[n-1]和dp[n-2]的问题,从而不断分解为简单的子问题,直到分解为最小子问题dp[0]=1,dp[1]=1。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/20735.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

智能学工系统实现学生管理

人才培养是高校的榜首要务&#xff0c;高校在抓好学生教育作业的一起&#xff0c;更多的是要加强对学生的办理作业。作为在校大学生健康成长的指导者和引路人&#xff0c;面临很多的学生办理作业内容杂乱&#xff0c;事无巨细&#xff0c;但在传统的办理方式下&#xff0c;尽管…

Java集合:数据存储与操作的瑞士军刀

Java集合概述 集合是用来存储多个元素的容器。文章从四个方面来概述下集合&#xff0c;让读者对集合有一个大致的了解。 一、 多样化的容器 Java 集合大致包含 2 大体系 Collection体系 List&#xff1a;存储有序、重复的元素 Set&#xff1a;存储无序、不可重复的元素…

【射击game】

编写射击游戏程序是一个复杂的过程&#xff0c;涉及到多个方面&#xff0c;包括游戏设计、编程、图形设计、音效等。下面是一个简化的射击游戏程序编写流程&#xff0c;使用Python语言和Pygame库作为示例。 环境准备 安装Python&#xff1a;确保你的计算机上安装了Python。安…

摸鱼大数据——Hive函数7-9

7、日期时间函数 Hive函数链接&#xff1a;LanguageManual UDF - Apache Hive - Apache Software Foundation SimpleDateFormat (Java Platform SE 8 ) current_timestamp: 获取时间原点到现在的秒/毫秒,底层自动转换方便查看的日期格式 常用 to_date: 字符串格式时间…

springboot获取当前数据库连接

要获取当前 Spring DataSource 的 URL&#xff0c;可以通过以下几种方法&#xff1a; 方法一&#xff1a;使用 JdbcTemplate 如果你使用的是 Spring 的 JdbcTemplate&#xff0c;可以通过 javax.sql.DataSource 获取连接&#xff0c;再获取它的 URL。 示例代码&#xff1a; …

linux服务器配置openssl

root用户登录进行操作&#xff1a; 1 执行openssl 若提示找不到openssl.cnf文件&#xff0c;可将/etc/pki/tls/openssl.cnf拷贝到对应目录即可。 2 创建server.key文件 openssl genrsa -des3 -out server.key 1024 需要输入一个密码&#xff0c;任意4个字符以上。 还可以删…

Harmonyos Next——图片上传与下载

Harmonyos Next——图片上传与下载 图片上传至服务器描述选取图片从相册选择图片通过拍摄获取图片 将获取的图片上传至服务器拷贝文件上传图片 图片下载 图片上传至服务器 描述 从手机相册中选择一张图片&#xff0c;然后上传至服务器 选取图片 在从相册或者拍摄获取的图片…

【Self-Attention——Transform—Bert】相关的基础理论

1.Self-Attention模型图解 传统的循环神经网络&#xff0c;如上左图1&#xff0c;并不能解决并行化的问题&#xff0c;右图就是一个self-Attention可以实现并行化&#xff0c;并且能解决对于所有信息的读取利用。 将self—Attention替换相应的GRU或者RNN&#xff0c;就能实现从…

单片机原理及应用复习

单片机原理及应用 第二章 在AT89S52单片机中&#xff0c;如果采用6MHz晶振&#xff0c;一个机器周期为 2us 。 时钟周期Tocs1focs 机器周期 Tcy12focs 指令周期&#xff1a;一条指令所用的时间&#xff0c;单字和双字节指令一般为单机器周期和双机器周期。 AT89S5…

Github 2024-06-02 开源项目日报Top10

根据Github Trendings的统计,今日(2024-06-02统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Python项目5TypeScript项目2Jupyter Notebook项目1Kotlin项目1Vue项目1Shell项目1ChatTTS:日常对话生成式语音模型 创建周期:4 天开发语言:J…

Java集合框架源码分析:LinkedHashMap

文章目录 一、LinkedHashMap集合简介二、LinkedHashMap集合底层的数据结构三、优缺点 一、LinkedHashMap集合简介 LinkedHashMap是Java中的一种特殊的数据结构&#xff0c;它是HashMap的一个子类&#xff0c;并实现了Map接口。LinkedHashMap是HashMap和双向链表的结合体&#…

Sentinel限流学习

Sentinel限流学习 初识Sentinel运行sentinel雪崩问题服务保护技术对比微服务整合Sentinel 限流规则簇点链路 流控模式-关联流控模式-链路流控模式有哪些&#xff1f; 流控效果流控效果-warm up流控效果-排队等待 热点参数限流隔离和降级Feign整合Sentinel线程隔离有两种方式实现…

【论文复现|智能算法改进】基于多策略麻雀搜索算法的机器人路径规划

目录 1.算法原理2.改进点3.结果展示4.参考文献5.代码获取 1.算法原理 【智能算法】麻雀搜索算法&#xff08;SSA&#xff09;原理及实现 2.改进点 改进的无限折叠迭代混沌映射 无限折叠迭代映射(ICMIC) 常用于图像加密方向的研究, 基本思想是首先生成[0,1]之间的混沌序列, …

摸鱼大数据——Hive函数10-12

10、堆内存错误 报错&#xff1a; Error while processing statement: FAILED: Execution Error, return code -101 from org.apache.hadoop.hive.ql.exec.mr.MapRedTask. Java heap space 解决方案: 在node1上面操作即可 方式1: 找到/export/server/hive/conf/hive-env.sh,添…

CTF本地靶场搭建——静态flag题型的创建

静态flag题型的创建 首先这里要说的是静态flag和动态flag。 在CTF&#xff08;Capture The Flag&#xff09;比赛中&#xff0c;静态flag的使用通常与特定的赛制或题目类型关联&#xff0c;而不是直接与题型绑定。静态flag意味着这些flag是预先设定好的&#xff0c;不会随比…

LangChain进行文本摘要 总结

利用LangChain进行文本摘要的详细总结 LangChain是一个强大的工具&#xff0c;可以帮助您使用大型语言模型&#xff08;LLM&#xff09;来总结多个文档的内容。以下是一个详细指南&#xff0c;介绍如何使用LangChain进行文本摘要&#xff0c;包括使用文档加载器、三种常见的摘…

MySQL 导出导入的101个坑

最近接到一个业务自行运维的MySQL库迁移至标准化环境的需求&#xff0c;库不大&#xff0c;迁移方式也很简单&#xff0c;由开发用myqldump导出数据、DBA导入&#xff0c;但迁移过程坎坷十足&#xff0c;记录一下遇到的各项报错及后续迁移注意事项。 一、 概要 空间问题源与目…

排序进阶----快速排序

当我们写了插入和希尔排序后&#xff0c;我们就应该搞更难的了吧。大家看名字就知道我们这篇博客的内容了吧。而且从名字上来看。快速排序就很快吧。那么为什么这个排序怎么能叫快速排序啊。我们希尔排序不是很快嘛。那么我们的快速排序肯定是有特殊之处嘞。不然这就太自负了。…

autodl服务器中YOLOx训练自己数据集

目录 本篇文章主要讲解使用YOLOx训练自己数据集&#xff0c;其中包括数据集格式转换~ 目录 一、数据集处理二、环境配置三、配置文件修改四、开始训练五、开始验证 一、数据集处理 第一步&#xff1a;将yolo格式的数据集转换成VOC格式 转换脚本&#xff1a;txt_to_xml.py f…