【数据结构陈越版笔记】2.1 引子【第2章 数据结构实现基础】

2.1 引子

数据结构的处理方法是从具体应用中抽象出共性的数据组织与操作方法,进而采用某种具体的程序涉及语言实现相应的数据存储与操作。
【例】给日常处理的数据进行统计分析
类型名称:统计数据集
数据对象集:N个元素 { x 1 , x 2 , . . . , x N } \{x_{1},x_{2},...,x_{N}\} {x1,x2,...,xN}的集合S
操作集

  1. ElementType Average(S, N):求S中N个元素的平均数;
  2. ElementType Max(S, N):求S中N个元素的最大值;
  3. ElementType Min(S, N):求S中N个元素的最小值;
  4. ElementType Median(S, N):求S中N个元素的中位数,这里的中位数指的是如果将S中的元素按从小到大的顺序依次排列,处在中间位置( ⌈ N / 2 ⌉ \lceil\mathrm{N} / 2\rceil N/2,大于等于N/2的最小整数)的那个元素。

(1)数据存储:对于上述问题,其数据对象是集合S,这也是最简单的一种数据组织方式。今后会有更复杂的组织方式如树和图等。
(2)操作实现:在确定数据的存储方式后,数据结构涉及的另一个问题是相关的操作(运算)如何实现。这些操作的实现需要利用程序涉及语言提供的另一个功能,即流程设计功能。在程序中,我们可以将程序的某个功能设计为函数,这一方面降低了程序设计的复杂性,另一方面也提高了程序设计的重用性。
【代码2.1】Average函数的实现

double Average(int S[], int N)
{int sum = 0;for(int i = 0; i < N; i++){sum+=S[i];}return (double)((double)(Sum))/((double)(N));
}

这个代码简单,不给出运行结果了
而对于中位数Median(S, N)问题则相对比较复杂,设法用一个循环简单地实现,有两种基本的解决思路。
方法1:基于排序,首先将集合S(数组)中的元素从大到小排序,取第 ⌈ N / 2 ⌉ \lceil\mathrm{N} / 2\rceil N/2(大于等于N/2的最小整数)处的元素就是中位数。
方法2:基于问题分解,求集合中位数的问题实际上就是另一个问题的特殊情况,即求集合中的第K大数问题。当 K = ⌈ N / 2 ⌉ K=\lceil\mathrm{N} / 2\rceil K=N/2时,集合的第K大数就是中位数。这个问题当然也可以用排序解决,但还有另一种更巧妙的方法,基本思路是:用一个基准数e将集合S分解为不包含e在内的两个小集合 S 1 S_{1} S1 S 2 S_{2} S2,其中 S 1 S_{1} S1的任何元素均大于等于e, S 2 S_{2} S2的任何元素均小于e,记 ∣ S ∣ |S| S代表集合S元素的个数,这样,如果 ∣ S 1 ∣ ≥ K |S_{1}|\ge K S1K,则说明第K大数在 S 1 S_{1} S1中;如果 ∣ S 1 ∣ |S_{1}| S1恰好等于K-1,说明e是第K大数;否则第K大数在 S 2 S_{2} S2中,并且是 S 2 S_{2} S2中的第 K − ∣ S 1 ∣ − 1 K-|S_{1}|-1 KS11大数。然后,可以用类似的思路继续在 S 1 S_{1} S1 S 2 S_{2} S2中查找,详见【LeetCode215】数组中的第K个最大元素,最后令 K = N / 2 K=N/2 K=N/2即可

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

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

相关文章

报错 Cannot read properties of undefined(reading‘addEventListener‘)如何解决

我在制作项目中遇到了一个问题&#xff0c;给大家分享一下&#xff0c;如下图&#xff1a; 问题&#xff1a;这是我给一个input输入框绑定的监听事件出现的报错 翻译&#xff1a;无法读取未定义的属性(读取 addEventListener ) 错误原因&#xff1a;js中操作的dom元素的函数方…

KL散度(Kullback-Leibler divergence)

K L KL KL散度&#xff08; K u l l b a c k − L e i b l e r d i v e r g e n c e Kullback-Leibler\ divergence Kullback−Leibler divergence&#xff09;&#xff0c;也被称为相对熵、互熵或鉴别信息&#xff0c;是用来衡量两个概率分布之间的差异性的度量方法。以下是对…

在vscode中调试,命令行出现错误信息ModuleNotFoundError: No module named ‘imp‘

在vscode中调试&#xff0c;命令行出现错误信息ModuleNotFoundError: No module named ‘imp’ 报错原因 VSCode的python扩展会使用debugpy库实现调试功能。在涉及qt组件加载时&#xff0c;debugpy的qt_loaders.py会尝试加载imp库。而在python3.12及以后的版本中&#xff0c;…

钉钉Stream模式推送程序环境部署

python3.10版本需要openssl1.1.1及以上版本 参考链接&#xff1a;https://blog.csdn.net/weixin_42806458/article/details/110678710 wget https://www.openssl.org/source/openssl-1.1.1q.tar.gz unzip openssl-1.1.1q.tar.gz cd openssl-1.1.1q ./config --prefix/usr/loc…

【Ant-Design-Vue动态表头并填充数据】

在 Ant Design Vue 中&#xff0c;动态表头和数据填充通常涉及两个主要步骤&#xff1a; 动态生成表头&#xff1a;这通常是通过 Vue 的动态数据绑定和组件属性来实现的。填充数据&#xff1a;使用 Vue 的数据属性&#xff08;data&#xff09;或计算属性&#xff08;computed…

LabVIEW软件开发任务的工作量估算方法

在开发LabVIEW软件时&#xff0c;如何准确估算软件开发任务的工作量。通过需求分析、功能分解、复杂度评估和资源配置等步骤&#xff0c;结合常见的估算方法&#xff0c;如专家判断法、类比估算法和参数估算法&#xff0c;确保项目按时按质完成&#xff0c;提供项目管理和资源分…

C++标准模板(STL)- 迭代器库-迭代器适配器 - 创建拥有从实参推出的类型的 std::move_iterator

迭代器库-迭代器原语 迭代器库提供了五种迭代器的定义&#xff0c;同时还提供了迭代器特征、适配器及相关的工具函数。 迭代器分类 迭代器共有五 (C17 前)六 (C17 起)种&#xff1a;遗留输入迭代器 (LegacyInputIterator) 、遗留输出迭代器 (LegacyOutputIterator) 、遗留向前迭…

【JKI SMO】框架讲解(一)

JKI State Machine是一款易于使用且功能强大的状态机模板&#xff0c;可以作为界面或者仪器工作流程的基础框架&#xff0c;但是他不能处理复杂系统的多任务并发机制&#xff0c;因为他是只能处理单个进程。 随之&#xff0c;JKI推出了基于面向对象封装的SMO框架&#xff0c;是…

【云原生】docker swarm 使用详解

目录 一、前言 二、容器集群管理问题 2.1 docker集群管理问题概述 2.1.1 docker为什么需要容器部署 2.2 docker容器集群管理面临的挑战 三、docker集群部署与管理解决方案 四、Docker Swarm概述 4.1 Docker Swarm是什么 4.1.1 Docker Swarm架构图 4.1.2 Docker Swarm几…

c++_0基础_讲解6 循环语句

for循环 C中的for循环是一种控制流语句&#xff0c;用于重复执行一组语句&#xff0c;直到指定条件为假。它是C中最常用的循环结构之一&#xff0c;提供了灵活的控制循环的方式&#xff0c;能够在各种情况下进行迭代和循环操作。 for循环由三个重要部分组成&#xff1a;初始化…

Windows下访问wsl的数据

Windows下访问wsl的数据 有些人感受到的是雨&#xff0c;而很多人感受到的只有淋湿。 Windows下的wsl说实话还是挺不错的&#xff0c;对于开发而言&#xff0c;效果相当的可以。 比如在某个文件夹&#xff0c;Windows编辑好代码后&#xff0c;直接右键打开wsl&#xff0c;就可…

HTML中的<a>标签使用指南

HTML中的<a>标签使用指南 HTML中的<a>标签&#xff0c;也就是超链接标签&#xff0c;是网页设计中不可或缺的元素之一。它允许用户从一个页面跳转到另一个页面&#xff0c;或者触发某些动作。以下是<a>标签的使用和属性的详细介绍。 <a>标签的主要作…

Vue3主题色变更原理版

在src文件下创建style文件夹index.css文件定义颜色 :root {--book-bgcolor: #125465; } 在main.ts文件导入全局css样式 import ./style/index.css 在目标页面使用颜色 <template><div class="bg"><button @click="changecolor">变色…

【数据结构】三路快速排序

1. 简介 传统快速排序用的是双路快速排序&#xff0c;即将大于基准值的部分放到基准值右侧&#xff0c;小于基准值的部分放到基准值左侧&#xff0c;但是这种算法面对过多的重复数据的数组&#xff0c;时间复杂度会增多&#xff0c;于是就有了三路快速排序的思想&#xff0c;其…

一个在C#中集成Python的例子

一个在C#中集成Python的例子。在C#中可以执行Python脚本&#xff0c;在Python中也可以调用C#宿主中的功能&#xff08;clr.AddReference(Business)&#xff09;。 文件说明 Debug为执行目录 Mgr.exe为执行文件 Py\init.py为python初始化脚本 Py\Lib.zip为python需要的模块&…

Linux丢包故障的定位与解决(自驾_ROS)

参考【https://www.cnblogs.com/zhangmingda/p/11671970.html】 链路层问题排查 netstat -i 查看关注的接口RX/TX-DRP和/RX/TX-OVR是否存在丢包 cat /proc/net/dev查看Receive与Transmit的fifo列&#xff0c;如果不为0说明存在ring buffer到达/生成速率高于内核处理速率&…

企业化运维(2)_nginx

###1.nginx源码安装部署### ###2.平滑升级### &#xff08;1&#xff09;版本升级 当服务器在运行时&#xff0c;需要升级的情况下&#xff0c;平滑升级即就是不断开服务器就可以进行升级&#xff0c;最大限度保证数据的完整性。 下载nginx新版本软件&#xff0c;正常执行./c…

PHP入门教程1:PHP的基础概念和基本语法

本文将从基础开始&#xff0c;介绍PHP的基础概念和基本语法。 PHP简介环境搭建基本语法变量和常量数据类型操作符常见错误和调试方法 1. PHP简介 PHP&#xff0c;全称是 “PHP: Hypertext Preprocessor”&#xff0c;是一种开源的通用脚本语言&#xff0c;尤其适用于Web开发…

蔡崇信“预言”:微软与OpenAI未来极有可能会分道扬镳

近日&#xff0c;在美国投行摩根大通于上海举行的第二十届全球中国峰会上&#xff0c;阿里巴巴集团联合创始人、董事局主席蔡崇信与摩根大通北亚区董事长兼大中华区投资银行业务副主席关金星&#xff08;Kam Shing Kwang&#xff09;进行了一场精彩对话。蔡崇信深入分享了他对公…

GitHub每周最火火火项目(6.10-6.16)

好的&#xff0c;以下是按照你的要求对每个项目进行的总结&#xff1a; 项目名称&#xff1a;roboflow / supervision 项目介绍&#xff1a;supervision 是一个用于计算机视觉的工具库&#xff0c;它提供了一系列的工具和函数&#xff0c;帮助用户更轻松地进行图像和视频数据的…