数据结构与算法-概念

计算机从解决数值计算问题到解决生活中的问题
现实生活中的问题涉及不同个体间的复杂联系
需要在计算机程序中描述生活中个体间的联系
数据结构主要研究非数值计算程序问题中的操作对象以及它们之间的关系而不是研究复杂的算法

数据结构

基本概念

数据:程序的操作对象,用于描述客观事物

数据的特点:
-可以输入到计算机
-可以被计算机程序处理

数据是一个抽象的概念,将其进行分类后得到程序设计语言中的类型。如:int,float,char等等

数据元素:组成数据的基本单位
数据项:一个数据元素由若干数据项组成
数据对象 – 性质相同的数据元素的集合
e.g.

struct _MyTeacher   //一种数据类型
{char	name[32];char	tile[32];int		age;char	addr[128];
};int main21()
{struct _MyTeacher t1; //数据元素struct _MyTeacher tArray[30]; //数据对象memset(&t1, 0, sizeof(t1));strcpy(t1.name, "name"); //数据项strcpy(t1.addr, "addr"); //数据项strcpy(t1.tile, "addr"); //数据项t1.age = 1;
}

数据元素之间不是独立的,存在特定的关系,这些关系即结构

数据结构指数据对象中数据元素之间的关系

数据结构图

数据的逻辑结构

指数据元素之间的逻辑关系。即从逻辑关系上描述数据,它与数据的存储无关,是独立于计算机的。逻辑结构可细分为4类
数据的逻辑结构

数据的物理结构

数据的物理结构

数据的运算

数据的运算

算法

基本概念

算法是特定问题求解步骤的描述
在计算机中表现为指令的有限序列
算法是独立存在的一种解决问题的方法和思想
对于算法而言,语言并不重要,重要的是思想

算法和数据结构区别

数据结构只是静态的描述了数据元素之间的关系
高效的程序需要在数据结构的基础上设计和选择算法

程序=数据结构+算法

总结:
算法是为了解决实际问题而设计的
数据结构是算法需要处理的问题载体
数据结构与算法相辅相成

算法特性

  • 输入:算法具有0个或多个输入
  • 输出:算法至少有1个或多个输出
  • 有穷性:算法在有限的步骤之后会自动结束而不会无限循环
  • 确定性:算法中的每一步都有确定的含义,不会出现二义性
  • 可行性:算法的每一步都是可行的

算法效率的度量

  • 事后统计法
    比较不同算法对同一组输入数据的运行处理时间
    缺陷

    • 为了获得不同算法的运行时间必须编写相应程序
    • 运行时间严重依赖硬件以及运行时的环境因素
    • 算法的测试数据的选取相当困难
    • 事后统计法虽然直观,但是实施困难且缺陷多
  • 事前分析估算
    依据统计的方法对算法效率进行估算
    影响算法效率的主要因素

    • 算法采用的策略和方法
    • 问题的输入规模
    • 编译器所产生的代码
    • 计算机执行速度
  • 大O表示法
    算法效率严重依赖于操作(Operation)数量
    在判断时首先关注操作数量的最高次项
    操作数量的估算可以作为时间复杂度的估算
    常见时间复杂度:
    时间复杂度1
    关系
    时间复杂度2

  • 算法的空间复杂度
    算法的空间复杂度通过计算算法的存储空间实现
    S(n) = O(f(n))
    其中,n为问题规模,f(n))为在问题规模为nn时所占用存储空间的函数
    大O表示法同样适用于算法的空间复杂度
    当算法执行时所需要的空间是常数时,空间复杂度为O(1)

空间与时间的策略

  • 多数情况下,算法执行时所用的时间更令人关注
  • 如果有必要,可以通过增加空间复杂度来降低时间复杂度
  • 同理,也可以通过增加时间复杂度来降低空间复杂度

转载于:https://www.cnblogs.com/cj5785/p/10664712.html

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

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

相关文章

腾讯联手联通推出车联网“网卡”,打“内容”+“流量”的组合拳

车载生态已经成为了一个兵家必争之地了,于商业前景而言,这是一个BAT都无法忽视的掘金胜地。 从市场数据来看,全球车联网市场年复合增长率达到25%,根据汽车之家大数据显示:自2014年以来,车联网上市新车型渗…

编程面试中的十个常见错误

本文由 伯乐在线 - darkinlight 翻译自 thegeekstuff。欢迎加入技术翻译小组。转载请参见文章末尾处的要求。 身为程序员,你肯定知道和其他技术工作面试比起来,编程工作的面试流程略有不同。 这篇文章会就你在编程面试中应当避免的10个问题展开讨…

费曼技巧与博客

费曼技巧与博客 什么是费曼技巧? 费曼技巧是一种学习方法,核心是以教促学。 具体实践 以学习费曼技巧为例: 确定学习目标为学习费曼技巧。寻找资料(网络、书籍、报刊等)学习费曼技巧,直到自己认为已经理解了…

阿里云服务器 CentOS 7上-- Docker 安装 网关(API-Getway)--KONG

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。 全程操作按官方文档来就可以了。 1.将 Kong 连接到 Cassandra 或 PostgreSQL 容器 Kong支持 2 种数据库:Cassandra 或 Post…

每个程序员都应该了解的内存知识

英文原文:lwn.net,翻译:开源中国 [编辑的话: Ulrich Drepper最近问我们,是不是有兴趣发表一篇他写的内存方面的长文。我们不用看太多就已经知道,LWN的读者们会喜欢这篇文章的。内存的使用常常是软件性能的决定性因子&…

山区建小学

题目描述 政府在某山区修建了一条道路&#xff0c;恰好穿越总共nn个村庄的每个村庄一次&#xff0c;没有回路或交叉&#xff0c;任意两个村庄只能通过这条路来往。已知任意两个相邻的村庄之间的距离为d_idi​&#xff08;为正整数&#xff09;&#xff0c;其中&#xff0c;0<…

idea debugger console 不见了--还原 console 图标

1 找了好久&#xff0c;也找不到&#xff0c;调试的时候挺麻烦的。 2 最后发现 有个一个重置&#xff0c;视图的按钮。点击一下就恢复 。 如下图。转自&#xff1a;https://blog.csdn.net/changdejie/article/details/64127026

实验五:任意输入10个int类型数据,排序输出,再找出素数

import java.util.Scanner; public class Pxsushu {public static void main(String[] args) {// TODO Auto-generated method stubScanner s new Scanner(System.in);int temp;//对数组事先声明并创建10个空间int[] a new int[10];//把输入的数存储为数组for (int i 0; i &…

Vue笔记(六)——Vue组件通信Vuex

组件通信 vue本身的组件通信 父>子&#xff1a;父组件向子组件传参或者调用子组件的方法子>父&#xff1a;子组件向父组件传参或者调用父组件的方法兄弟之间&#xff1a;兄弟组件之间传参或者调用方法父子通信 传参 - props思路&#xff1a;定义子组件的属性&#xff08;…

灼灼夏日 - 遥思故乡 - 赤子无相忘

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 偶然翻看旧照片&#xff0c; 想起没有带过来的一本本诗集、散文集、手抄本、画册 ... 想起母亲的寄挂 ... 想起父亲的沉默 ... 想起少…

钱生钱最好的办法是什么?

当你养成理财的六种好习惯时&#xff0c;你能钱生钱了。这六种习惯是&#xff1a; 习惯一&#xff1a;记录财务情况。能够衡量就必然能够了解&#xff0c;能够了解就必然能够改变。如果没有持续的、有条理的、准确的记录&#xff0c;理财计划是不可能实现的。因此&#xff0c;在…

grid - 隐式命名网格线名称

1.隐式的指定网格线反向指定了隐式的网格区域名称&#xff0c;命名的网格区域隐式的命名了网格线名称. 指定网格区域会给网格区域边线添加隐式的网格线名称。这些网格线的命名是基于网格区域来命名&#xff0c;只是在网格区域名称的后面添加后缀-start或-end. 1 <view class…

前端笔试题小结(一)

前端笔试题小结&#xff08;一&#xff09; 2020-03-13 题目一&#xff1a; 将一个js数组去重。 样例&#xff1a; 输入&#xff1a;[ 1, “apple”, 3, “a”, 3, 1, 5, 6, “a”, 4 ] 输出&#xff1a;[ 1, “apple”, 3, “a”, 5, 6, 4 ] 分析1&#xff1a; 将两个数组循…

2019-3-1

伪静态: .html url(^page/(?P<id>\d).html/$,views.page,namepages) /page/1|2|3.html/ | {% url pages 1|2|3 %} 3.request对象 --method,GET,POST --FILES,META,body,path,get_full_path(),is_ajax(),COOKIE,session 4.CBV处理请求的另外一种方式 from django.…

java 使用 new Date() 和 System.currentTimeMillis() 获取当前 时间戳

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 在开发过程中&#xff0c;通常很多人都习惯使用new Date()来获取当前时间。 使用起来也比较方便&#xff0c;同时还可以获取与当前时间…

持币过节也能让钱生钱

今天是国庆长假前最后一个交易日。从盘面上看&#xff0c;投资者包括部分基金公司减仓明显。对于目前大盘高位震荡&#xff0c;很多人选择落袋为安&#xff0c;持币过节&#xff0c;不失为明智之举。但你知道吗&#xff0c;持币过节也能让钱生钱。今天我就来为各位讲讲其中的奥…

关于cat命令修改文件内容(导入变量符号以及变量内容)

关于cat命令修改文件内容&#xff08;导入变量符号以及变量内容&#xff09; cat >1.txt<<END $11 $22 $1 $2 END 查看文件内容为&#xff1a; [rootserver04 ~]# cat 1.txt 1 2[rootserver04 ~]# 说明导入的$1,$2自动被解析了。但是当我们想输入一些变量而不被解析…

Android - AsyncTask你知道多少?

http://www.cnblogs.com/qlky/p/5658070.html 为什么asyncTask最好在主线程初始化&#xff1f;在子线程怎么办&#xff1f; AsyncTask四个方法的执行顺序&#xff1f; mWorker和mFuture对象分别是什么&#xff1f;有什么作用&#xff1f;和doInbackground还有postExecute有什么…

2020-3-15

题目一&#xff1a; 问答 请写出如下代码运行后产生的结果&#xff0c;并给出解释&#xff0c;说明结果是如何得出的。 setTimeout(() > console.log(a)); Promise.resolve().then(() > console.log(b);).then(() > Promise.resolve(c).then((data) > {setTimeout…

Kong-dashboard 安装 启动运行

Kong Dashboard 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 Kong is a scalable, open source API Layer (also known as a API Gateway, or API Middleware). Kong runs in front o…