个人理解数据结构与算法基本概念

简介: 个人理解数据结构与算法基本概念

个人理解数据结构与算法基本概念


算法:算法是解决特定问题求解步骤的描述,在计算机中表现为指令的有限序列,并且每条指令表示一个或多个操作。

算法的五个基本特征:

输入:算法具有零个或者多个输入。

输出:算法至少有一个或多个输出。

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

确定性:

      1.算法的每一个步骤都具有确定的含义,不会出现二义性。

      2.算法在一定的条件下,只有一条执行路径,相同的输入只能有唯一的输出结果。

      3.算法的每个步骤都应该被精确定义而无歧义。

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

算法设计的要求:

正确性:算法的正确性是指算法至少应该具有输入/输出和价格处理无歧义性,能正确反映问题的需求/能够得到问题的正确答案。

大体分为以下四个层次:

       1.算法程序没有语法错误。

       2.算法程序对于合法输入能够产生满足要求的输出。

       3.算法程序对于非法输入能够产生满足规格的说明。

       4.算法成语对于故意刁难的测试输入都有满足要求的输出结果。

可读性:算法设计另一个目的是为了便于阅读/理解和交流。

健壮性:当输入数据不合法时,算法也能做出相关处理,而不是产生异常/崩溃或莫名其妙的结果。

 

数据结构分类

一维:

       基础:数组(array)、链表(linked list)。

       高级:栈(stack)、队列(queue)、双端队列(deque)、集合(set)、映射(hash or map)、et

二维:

       基础:树(tree)、图(fraph)。

       高级:二叉搜索树(binary search tree 、red-black tree 、AVL)、堆(heap)、并查集(disjoint set)、字典树Trie()、etc。

特殊:

        位运算(Bitwise)、布隆过滤器(Bloom Filter)。

        LRU Cache。

 

算法:

       if-else,switch  -----> branch。

       for,while loop ------> lteration。

       递归 Recursion(Divide & Conquer,Backtrace)。

       搜索search:深度优先搜索(Depth first search),广度优先搜索(Breadth first search),A*,etc.

      动态规划(Dynamic Programming)。

      二分查找(Binary Search)。

      贪心算法(Greedy)。

      数学(Math),几何(Geometry)。

相关文章
|
1天前
|
机器学习/深度学习 算法 C语言
详细介绍递归算法在 C 语言中的应用,包括递归的基本概念、特点、实现方法以及实际应用案例
【6月更文挑战第15天】递归算法在C语言中是强大力量的体现,通过函数调用自身解决复杂问题。递归涉及基本概念如自调用、终止条件及栈空间管理。在C中实现递归需定义递归函数,分解问题并设定停止条件。阶乘和斐波那契数列是经典应用示例,展示了递归的优雅与效率。然而,递归可能导致栈溢出,需注意优化。学习递归深化了对“分而治之”策略的理解。**
11 7
|
10天前
|
存储
数据结构学习记录——什么是堆(优先队列、堆的概念、最大堆最小堆、优先队列的完全二叉树表示、堆的特性、堆的抽象数据类型描述)
数据结构学习记录——什么是堆(优先队列、堆的概念、最大堆最小堆、优先队列的完全二叉树表示、堆的特性、堆的抽象数据类型描述)
10 2
|
10天前
|
存储 算法
数据结构和算法学习记录——特殊线性表之队列-队列的概念、队列结构体类型定义 、基本接口函数、初始化函数、销毁队列函数、入队列函数、判断队列是否为空、出队列函数、读取队头队尾的数据 、计算队列数据个数
数据结构和算法学习记录——特殊线性表之队列-队列的概念、队列结构体类型定义 、基本接口函数、初始化函数、销毁队列函数、入队列函数、判断队列是否为空、出队列函数、读取队头队尾的数据 、计算队列数据个数
8 0
|
10天前
|
算法
数据结构和算法学习记录——特殊线性表之栈(上)-栈的概念、栈的结构、链式栈数组栈、栈的结构体定义、栈的基本接口函数、栈顶初始化函数
数据结构和算法学习记录——特殊线性表之栈(上)-栈的概念、栈的结构、链式栈数组栈、栈的结构体定义、栈的基本接口函数、栈顶初始化函数
4 0
|
10天前
|
存储 算法
数据结构和算法学习记录——线性表之顺序表(顺序表概念、结构、顺序表接口函数-头插头删、尾插尾删)
数据结构和算法学习记录——线性表之顺序表(顺序表概念、结构、顺序表接口函数-头插头删、尾插尾删)
8 0
|
10天前
|
存储 NoSQL 算法
Redis集群,集群的概念 三种主流分片方式1.哈希求余 一致性哈希算法:方案三:哈希槽分区算法问题一Redis集群是最多有16384个分片吗问题二:为什么是16384个,集群扩容:1.新的主节点
Redis集群,集群的概念 三种主流分片方式1.哈希求余 一致性哈希算法:方案三:哈希槽分区算法问题一Redis集群是最多有16384个分片吗问题二:为什么是16384个,集群扩容:1.新的主节点
|
11天前
|
JavaScript 数据库
关系数据库:关系数据结构基础与概念解析
关系数据库:关系数据结构基础与概念解析
12 1
|
24天前
|
存储 算法
[数据结构]—二叉树基本概念
[数据结构]—二叉树基本概念
|
26天前
|
存储 机器学习/深度学习 算法
数据结构与算法⑬(第四章_中_续二)堆解决Topk问题+堆的概念选择题
数据结构与算法⑬(第四章_中_续二)堆解决Topk问题+堆的概念选择题
30 3
|
26天前
|
存储 移动开发 算法
数据结构与算法⑩(第四章_上)树和二叉树和堆的概念及结构(下)
数据结构与算法⑩(第四章_上)树和二叉树和堆的概念及结构
32 0