数据结构和算法学习笔记(一)

本文介绍了程序设计的核心组成部分——数据结构与算法。数据结构包括集合、线性、树形和图形结构,重点关注逻辑结构,同时提到了顺序和链式两种物理存储方式。算法则被定义为解决问题的步骤序列,具备输入、输出、有穷性、确定性和可行性五大特征。讨论了算法在实际应用中的意义和重要性。
摘要由CSDN通过智能技术生成

 非原创 内容来自网课 只做学习笔记自己复习用 这节来自bilibili up小甲鱼 

一、绪论:

        1、程序设计=数据结构+算法  数据结构就是关系,是数据元素相互之间存在的一种或多种特定关系的集合。

        2、传统上,我们把数据结构分为逻辑结构和物理结构,逻辑结构是指数据对象中数据元素之间的相互关系,也是我们今后最需要关注和讨论的问题,而物理结构是指数据的逻辑结构在计算机中的存储形式。

        3、四种逻辑结构:

         (1)集合结构

               

                   集合结构中的元素除了同属于一个集合外,没有其他关系。

        (2)线性结构

                       

                 线性结构中的数据元素是一对一的关系。

    (3)树形结构

                       

                 树形结构中的元素存在一对多的层次关系,例如3p,4p等。

    (4)图形结构

                       

              图形结构中的元素存在多对多的层次关系。

4、物理结构

  物理结构实际上研究的就是如何把数据元素存储到计算机的存储器中,而数据元素的存储结构形式有两种:顺序存储和链式存储。

 (1)顺序存储结构:是把数据元素存放在地址连续的存储单元里,其数据间的逻辑关系和物理关系是一致的。比如123刚好放在位置相连的123的存储单元里(数组就是这样)。

           

 (2)链式存储结构:是把数据元素存放在任意的存储单元里,这组存储单元可以是连续的,也可以是不连续的。很显然,这样说的话链式存储结构的数据元素存储关系并不能反映其逻辑关系,因此需要用一个指针存放数据元素的地址,这样通过地址就可以找到相关联数据元素的位置。比如在医院排号的时候,1号和2号可以在任意位置坐着,不需要挨着,但是2要注意1到了没有。

  

图中,6挨着8,但是6不指向8,而是指向7。

二、算法

1、定义:算法是解决特定问题求解步骤的描述,在计算机中表现为指令的有限序列,并且每条指令表示一个或多个操作。(其实就是解决问题的方法 可以有多个)

2、算法的五个基本特征:

  (1)输入:算法具有零个或者多个输入,尽管对于绝大多数算法来说,输入参数都是必要的。但是也有时候不需要参数,比如打印。

  (2)输出:算法至少有一个或者多个输出,形式上可以是打印形式输出,也可以是返回一个值或者多个值。

  (3)有穷性:指算法在执行有限的步骤之后,自动结束而不会出现无限循环,并且每一个步骤都在可以接受的时间内完成。

  (4)确定性:算法的每一个步骤都具有确定的含义,不会出现二义性。算法在一定条件下,只有一条执行路径,相同的输入只能有唯一的输出结果。算法的每个步骤都应该被精确定义而无歧义。

  (5)可行性:算法的每一步都必须是可行的,也就是说,每一步都能够通过执行有限次数完成。           

(本来看的是小甲鱼的网课 但由于各种原因 看不下去了 所以以后内容不用他的啦)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值