软件设计师-应用技术-数据结构及算法题4

考题形式:

  • 第一题:代码填空 4-5空 8-10
  • 第二题:时间复杂度 / 代码策略
  • 第三题:拓展,跟一组数据,把数据带入代码中,求解

基础知识及技巧:

1. 分治法:

基础知识:

  • 概念:对于一个规模为n的问题,若该问题可以容易地解决则直接解决;否则,将其分解为k个规模较小的子问题,这些子问题相互独立,并且与原问题形式相同,递归地解决这些子问题,然后,将各子问题的解合并得到原问题的解。
  • 步骤:分解、解决、合并。
  • 特点:

递归技术:

  • 概念:在运行的过程中调用自己的过程。

二分查找法:

2. 回溯法:

概念:回溯法也称为试探法,是一种选优搜索法,按选优条件向前搜索,以达到目标。但当搜索到某一步时,发现原先选择并不优或者达不到目标,就回退一步重新选择。这种走不通就退回再走的技术就是回溯法。背

N皇后问题:

  • 软考使用一维数组存储答案:
    • q[n+1] (数组1位置表示第1行皇后存储的列号,数组2位置表示第2行皇后存储的列号)
  • 判断两个皇后在同一列:
    • Qi 的列号 == Qj的列号 (Qi 表示第i个皇后、Qj表示第j个皇后)
  • 判断两个皇后在同一斜线:
    • abs(Qi行 - Qj行) == (Qi列 - Qj列)
  • 判断皇后没有超过棋盘:
    • q[j]
  • 判断皇后是否找到最后一列:
    • j == n ( j:表示正在摆放第j个皇后)
  • 回溯:
    • 将还原第j个皇后的位置为0:q[j] = 0
    • 回溯到上一个j:j = j - 1

3. 贪心法:

  • 概念:总是做出当前来说最好的选择,而并不从整体上加以考虑,它所做的每步选择只是当前步骤的局部最优选择,但从整体来说不一定是最优的选择。由于它不必为了寻找最优解而穷尽所以可能解,因此,其耗费时间少,一般可以快速得到满意的解,但得不到最优解。
  • 背包问题:

4. 动态规划法:

  • 概念:在求解问题中,对于每一步决策,列出各种可能的局部解,再依据某种判定条件,舍弃那些肯定不能得到最优的局部解,在每一步都进过刷选,以每一步都是最优解来保证全局是最优解。

0-1背包问题:

确认子问题范围,画出表格:

  • 行 i:0~4 ,列 j: 0~5,其中:i -> 物品数量 j -> 背包容量。
  • 表中每个单元代表:从前 i 个物品中选,背包容量为 j 时的最大价值。

公式:

  • 物品价值和物品重量数组

// 物品价值 - 索引0位置不用 int[] v = new int[]{0, 2, 4, 5, 6}; // 物品重量 - 索引0位置不用 int[] w = new int[]{0, 1, 2, 3, 4};

  • "不选第 i 个 物品" = 从前 i -1 个物品中选,背包容量为 j 时的最大值。

int not = f[i][j] = f[i - 1][j]

  • "选择第 i 个物品" = 第 i 个物品的价值 + 从前 i - 1 个物品中选,背包容量为"j - 第 i 个物品的质量"时的最大价值。 前提条件:背包容量 j 大于等于 第 i 个物品的重量才能选。

int yes = 0 // 背包容量j 等于 第i个物品的重量时,当前最大价值 = 第i物品的价值 if(j == w[i]){ yes = f[i] [j] = v[i] } // 背包容量j 大于 第i个物品的重量时,当前最大价值 = 第i物品的价值 + // 从前i-1个物品中选,背包容量为"j -第i个物品的质量"时的最大价值 if(j > w[ i ]){ yes = f[i] [j] = v[i] + f[i - 1][j -w[i]] }

  • 从前 i 个物品中选,背包容量为 j 时的最大价值 = "不选第 i 个 物品" 和 "选择第 i 个物品" 两者的最大值

f[i][j] = max(not,yes)

5. C语言语法:

  • return 0 ; 返回假 return 1 ; 返回真

答题技巧:

  • 先处理除补全代码以外的题,再填写代码。

例题1:

问题1:

(1) j=0 (2) b[j] = b[j] + s[i] (3) min =temp (4) b[m] = b[m] + s[i]

问题2:

(5)贪心算法 (6)贪心算法 (7)O(n²) (8)O(n²)

问题3:

(9)

(10)

(11)不能得到最优解, 这里的都是使用的贪心策略。

例题2:

问题1:

(1)k

首先,函数void merge(int arr[],int p,int q,int r)的意思是:对子数组 arr[p...q]和子数组 arr[q+1...r]进行合并。

因此,第一空为k当数组长度为1时,停止递归,因为此时该数组有序,则第三空为 begin

合并了begin到mid之间的元素,继续合并mid+1到end之间的元素,则第四空为 mergeSort(arr,mid+1,end)。

问题2:

(5) 分治法 (6)T(n) =2T(n/2) +O(n) (7) O(nlogn)(8)O(n)

归并算法实际上就是将数组一直往下分割,直到分割到由一个元素组成的n个子数组,再往上两两归并。将数组进行分割需要logN 步,因为每次都是讲数组分割成两半(2x= N,x = logN)。合并N个元素,需要进行N步,也就是O(N),则总的时间复杂度为 O(NlogN)。

合并过程中,使用了n个中间变量存储,left = (int*)malloc((n1+1)*sizeof(int))。所以空间复杂度为 O(n)。

递归式 todo 不会

推导递归式: 假设n个元素进行归并排序需要T(n),可以将其分割成两个分别有n/2个元素的数组分别进行归并,也就是 2T(n/2),在将这两个合并,需要 O(n)的时间复杂度。则推导公式为 T(n) = 2T(n/2)+o(n)。

问题3:

n1+ n2

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

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

相关文章

语音识别--降噪

⚠申明: 未经许可,禁止以任何形式转载,若要引用,请标注链接地址。 全文共计3077字,阅读大概需要3分钟 🌈更多学习内容, 欢迎👏关注👀【文末】我的个人微信公众号&#xf…

uniapp的app端推送功能,不使用unipush

1&#xff1a;推送功能使用htmlPlus实现&#xff1a;地址HTML5 API Reference (html5plus.org) 效果图&#xff1a; 代码实现&#xff1a; <template><view class"content"><view class"text-area"><button click"createMsg&q…

什么是DDoS攻击?DDoS攻击的原理是什么?

一、DDoS攻击概念 DDoS攻击又叫“分布式拒绝服务”(Distributed DenialofService)攻击&#xff0c;它是一种通过控制大量计算机、物联网终端或网络僵尸&#xff08;Zombie&#xff09;来向目标网站发送大量请求&#xff0c;从而耗尽其服务器资源&#xff0c;导致正常用户无法访…

设计网页用什么软件

在设计网页时&#xff0c;可以使用多种软件来完成不同的任务。以下是一些常用的网页设计软件&#xff0c;以及它们的特点和用途。 1. Adobe Photoshop&#xff1a; Adobe Photoshop 是一款功能强大的图像编辑软件。在网页设计中&#xff0c;它常用于创建和编辑网页所需的图像、…

手动配置dns后网速变慢

之前因为自动的dns能上qq但打不开网页&#xff0c;就手动设置了一个&#xff0c;结果近些天时不时出现网页图片加载慢的问题&#xff0c;影响到我看美女图片了&#xff0c;是可忍熟不可忍 测了下网速&#xff0c;很快&#xff0c;下载上传都是三位数的&#xff0c;那显然不是网…

RabbitMQ是如何保证消息可靠性的?——Java全栈知识(16)

RabbitMQ 的消息不可靠也就是 RabbitMQ 消息丢失只会发生在以下几个方面&#xff1a; 生产者发送消息到 MQ 或者 Exchange 过程中丢失。Exchange 中的消息发送到 MQ 中丢失。消息在 MQ 或者 Exchange 中服务器宕机导致消息丢失。消息被消费者消费的过程中丢失。 大致就分为生…

Star-CCM+分配零部件至区域1-将所有零部件分配至区域

前言 Star-CCM中&#xff0c;在划分网格之前需要将零部件分配至区域&#xff0c;然后才可以划分网格。如下图1所示&#xff0c;分配零部件至区域需要选择创建区域的方式、创建边界的方式以及交界面的类型。 图1 将零部件分配至区域 1 创建区域的方式选择 如下图2所示&#x…

基于Spring Boot的家具网站设计与实现

基于Spring Boot的家具网站设计与实现 开发语言&#xff1a;Java 框架&#xff1a;springboot JDK版本&#xff1a;JDK1.8 数据库工具&#xff1a;Navicat11 开发软件&#xff1a;eclipse/myeclipse/idea 系统部分展示 系统前台主界面图&#xff0c;用户可进入家具网站可查看…

探索大模型能力--prompt工程

1 prompt工程是什么 1.1 什么是Prompt&#xff1f; LLM大语言模型终究也只是一个工具&#xff0c;我们不可能每个人都去训一个大模型&#xff0c;但是我们可以思考如何利用好大模型&#xff0c;让他提升我们的工作效率。就像计算器工具一样&#xff0c;要你算10的10倍&#x…

Java IO类之FilterOutputStream的研究与应用

哈喽&#xff0c;各位小伙伴们&#xff0c;你们好呀&#xff0c;我是喵手。运营社区&#xff1a;C站/掘金/腾讯云&#xff1b;欢迎大家常来逛逛 今天我要给大家分享一些自己日常学习到的一些知识点&#xff0c;并以文字的形式跟大家一起交流&#xff0c;互相学习&#xff0c;一…

RCE学习(一)

一.知识点 RCE&#xff1a;远程命令/代码执行漏洞&#xff0c;简称为RCE漏洞&#xff0c;可以直接向服务器后台远程注入操作系统的命令或者代码&#xff0c;从而拿到服务器后台的权限。RCE分为远程执行命令&#xff08;执行ping命令&#xff09;和远程代码执行eval 简单来说就…

VMware导入ova/ovf虚拟机文件

1.文件-打开-ova文件 2.为新虚拟机起名称 3.等待导入 4.导入完成&#xff0c;可以开始使用 参考链接&#xff1a;VMware导入ova/ovf虚拟机文件

浅谈Session和Cookie

各位大佬光临寒舍&#xff0c;希望各位能赏脸给个三连&#xff0c;谢谢各位大佬了&#xff01;&#xff01;&#xff01; 目录 1.Cookie 2.Sesssion&#xff08;会话&#xff09; 3.Session和Cookie的联系 4.总结 1.Cookie Cookie是客户端存储数据的机制&#xff0c;一般是…

英语学习笔记5——Nice to meet you.

Nice to meet you. 很高兴见到你。 词汇 Vocabulary Mr. 先生 用法&#xff1a;自己全名 / 姓 例如&#xff1a;Mr. Zhang Mingdong 或 Mr. Zhang&#xff0c;绝对不能是 Mr. Mingdong&#xff01; Miss 女士&#xff0c;小姐 未婚 用法&#xff1a;自己全名 / 姓 例如&#…

【ROMA核心特性数据、服务、消息、设备集成及统一运维】

1、数据集成 FDI旨在解决多种数据源的快速灵活集成能力&#xff0c;您可以在任意时间、任意地点、任意系统之间实现实时数据订阅和定时增量数据迁移。 &#xff08;1&#xff09;数据集成任务的生命周期管理 &#xff08;2&#xff09;FDI支持修改数据集成任务的信息、查看数…

初识Node.js-认识node(安装Node.js环境配置)

目录 一、node介绍 1.概念和特点 2.核心功能 3.应用场景 二、Node初使用 1.安装node配置 windows上安Node.js 1.windows安装包&#xff08;.msi&#xff09; 2、Windows 二进制文件 (.exe)安装 Linux 上安装 Node.js 直接使用已编译好的包 Ubuntu 源码安装 Node.js …

【JVM】垃圾回收机制(Garbage Collection)

目录 一、什么是垃圾回收&#xff1f; 二、为什么要有垃圾回收机制&#xff08;GC&#xff09;&#xff1f; 三、垃圾回收主要回收的内存区域 四、死亡对象的判断算法 a&#xff09;引用计数算法 b&#xff09;可达性分析算法 五、垃圾回收算法 a&#xff09;标记-清除…

GDPU 天码行空11

&#xff08;一&#xff09;实验目的 1、掌握JAVA中IO中各种类及其构造方法&#xff1b; 2、重点掌握IO中类所具有的IO操作方法&#xff1b; 3、熟悉软件中登录模块的开发方法&#xff1b; 4、掌握IO中读写常用方法。 5、进一步熟悉正则规则的使用方法。 &#xff08;二&…

ue引擎游戏开发笔记(32)——为游戏添加新武器装备

1.需求分析&#xff1a; 游戏中角色不会只有一种武器&#xff0c;不同武器需要不同模型&#xff0c;甚至可能需要角色持握武器的不同位置&#xff0c;因此需要添加专门的武器类&#xff0c;方便武器后续更新&#xff0c;建立一个武器类。 2.操作实现&#xff1a; 1.在ue5中新建…

如何用DeepDiff测接口数据源变更?

开发同学最近变更了部分业务查询接口底层的数据源&#xff0c;希望测试同学能够针对这些接口进行一些回归验证&#xff0c;校验底层数据源更新前后业务查询接口返回的一致性&#xff0c;保证更新后对正常业务没有影响。 这个回归测试和一般接口测试有所区别&#xff0c;不仅仅…