软件设计师-应用技术-数据结构及算法题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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

取消vscode go保存时自动格式化代码

go:v1.22.0 vscode go 插件:v0.41.4 setting.json formatOnSave: 保存文件时,是否执行格式化 codeActiosnOnSave:保存文件时,是否执行某些操作 organizeImports: 不再改动import()里面的包

分类规则挖掘(三)

目录 四、贝叶斯分类方法(一)贝叶斯定理(二)朴素贝叶斯分类器(三)朴素贝叶斯分类方法的改进 五、其它分类方法 四、贝叶斯分类方法 贝叶斯 (Bayes) 分类方法是以贝叶斯定理为基础的一系列分类算法的总称。贝…

python中numpy库使用

array数组 生成array数组 将list转化为array数组 import numpy as np np.array([1,2],typenp.int32)其中dtype定义的是元素类型,np.int32指32位的整形 如果直接定义dtypeint 默认的是32位整形。 zeors和ones方法 zeros()方法,该方法和ones()类似&a…

Qt——入门基础

目录 Qt入门第一个应用程序 main.cpp widget.h widget.cpp widget.ui .pro Hello World程序 对象树 编辑框 按钮 Qt 窗口坐标系 Qt入门第一个应用程序 main.cpp 这就像一开始学语言时都会打印一个“Hello World”一样,我们先来看看创建好一个项目后&…

ModuleNotFoundError: No module named ‘PyQt5‘

运行python程序的时候报错:ModuleNotFoundError: No module named ‘PyQt5‘ 这是因为没有安装pyqt5依赖包导致的,安装一下即可解决该问题。 安装依赖 pip install PyQt5 -i https://pypi.tuna.tsinghua.edu.cn/simple 这里是使用的清华镜像源进行安装…

数据库系统原理实验报告5 | 数据查询

整理自博主本科《数据库系统原理》专业课自己完成的实验报告,以便各位学习数据库系统概论的小伙伴们参考、学习。 专业课本: ———— 本次实验使用到的图形化工具:Heidisql 目录 一、实验目的 二、实验内容 1.找出读者所在城市是“shangh…

STM32G0存储器和总线架构

文章目录 前言一、系统架构二、存储器构成三、存储器地址映射四、存储器边界地址五、外设寄存器边界地址 前言 此文章是STM32G0 MCU的学习记录,并非权威,请谨慎参考。 STM32G0主流微控制器基于工作频率可达64 MHz的高性能Arm Cortex-M0 32位RISC内核。该…

GEE数据集——DeltaDTM 全球沿海数字地形模型数据集

DeltaDTM 全球沿海数字地形模型产品 简介 DeltaDTM 是全球沿岸数字地形模型(DTM),水平空间分辨率为 1 弧秒(∼30 米),垂直平均绝对误差(MAE)为 0.45 米。它利用 ICESat-2 和 GEDI …

内容安全(IPS入侵检测)

入侵检测系统( IDS )---- 网络摄像头,侧重于风险管理,存在于滞后性,只能够进行风险发现,不能及时制止。而且早期的IDS误报率较高。优点则是可以多点进行部署,比较灵活,在网络中可以进…

【java9】java9新特性之改进JavaDocs

Java9在JavaDocs方面的主要新特性是,其输出现在符合兼容HTML5标准。在之前的版本中,默认的HTML版本是 HTML4.01,但在Java9及之后的版本中,JavaDocs命令行工具将默认使用HTML5作为输出标记语言。这意味着,使用JavaDocs工…

Markdown 精简教程(胎教级教程)

文章目录 一、关于 Markdown1. 什么是 Markdown?2. 为什么要用 Markdown?3. 怎么用 Markdown?(编辑软件) 二、标题1. 常用标题写法2. 可选标题写法3. 自定义标题 ID4. 注意事项 三、段落四、换行五、字体选项1. 粗体2.…

跨境电商行业分析-商品出海的四大路径

1. 跨境电子商务模式和国内电子商务模式【区别】 最大的不同点有3个: 达成交易的双方是属于不同【关境】的交易主体商品通过众多电子商务平台/独立站等,进行支付结算通过国际物流的方式(海运/铁路/空运/卡车)进行报关、清关、派…

anconda创建虚拟环境,使用虚拟环境(基于win平台)

假设已经安装了anconda,打开anaconda的 shell。 查看已存在的虚拟环境,base是默认的,不用理会,后面的yolov5就是用户创建的 #查看有那些虚拟环境 (base) PS C:\Users\x> conda info -e # conda environments: # base …

如何判断代理IP质量?

由于各种原因(从匿名性和安全性到绕过地理限制),代理 IP 的使用变得越来越普遍。然而,并非所有代理 IP 都是一样的,区分高质量和低质量的代理 IP 对于确保流畅、安全的浏览体验至关重要。以下是评估代理 IP 质量时需要…

计划订单转采购申请的增强点和可以增强的内容

MD15 MD14 计划订单转采购申请,涉及的增强点和增强内容 对于外协的采购申请,有时候需要对组件的内容做一些特殊的处理,但是处理组件清单的增强ME_COMPONENTS_UPDATE的增强点(这个增强点对于手工创建的外协PR、外协PO,外协pr转外协…

Day21 代码随想录打卡|字符串篇---右旋转字符串

题目(卡码网 T55): 字符串的右旋转操作是把字符串尾部的若干个字符转移到字符串的前面。给定一个字符串 s 和一个正整数 k,请编写一个函数,将字符串中的后面 k 个字符移到字符串的前面,实现字符串的右旋转…

Pycharm无法链接服务器环境(host is unresponsived)

困扰了很久的一个问题,一开始是在服务器ubuntu20.04上安装pycharm community,直接运行服务器上的pycharm community就识别不了anaconda中的环境 后来改用pycharm professional也无法远程连接上服务器的环境,识别不了服务器上的环境&#xff…

[力扣题解]102.二叉树的层序遍历

题目&#xff1a;102. 二叉树的层序遍历 代码 迭代法 class Solution { public:vector<vector<int>> levelOrder(TreeNode* root) {queue<TreeNode*> que;TreeNode* cur;int i, size;vector<vector<int>> result;if(root ! NULL){que.push(ro…

Pycharm导入自定义模块报红

文章目录 Pycharm导入自定义模块报红1.问题描述2.解决办法 Pycharm导入自定义模块报红 1.问题描述 Pycharm 导入自定义模块报红&#xff0c;出现红色下划线。 2.解决办法 打开【File】->【Setting】->【Build,Execution,Deployment】->【Console】->【Python Con…

【前端--Vue】组件之间的多种通信方式,一文彻底搞懂组件通信!

本篇将重点讲解vue中的多种组件通信方式&#xff0c;包括【父传子】【子传父】【兄弟组件通信】【依赖注入】等等&#xff0c;并提供具体案例来让小伙伴们加深理解、彻底掌握&#xff01;喜欢的小伙伴们点赞收藏&#xff0c;持续关注哦~&#x1f495; &#x1f49f; 上一篇文章…