摘要:
线性搜索(Linear Search)是一种非常简单的搜索算法,它按顺序遍历列表(或数组)中的每个元素,直到找到所需的元素或遍历完整个列表。下面我会描述线性搜索的实现原理、一步步数据演示,并给出Java代码示例。 实现原理 线性搜索的原理是遍历整个数据集合(通常是一个数组或列表),对集合中的每个元素 阅读全文
posted @ 2024-05-27 18:54
JackYang
阅读(458)
评论(0)
推荐(0)
摘要:
搜索算法的分类与特性 搜索算法是用于在数据集中查找特定元素的算法。以下是几种常见的搜索算法及其起源、原理、时间复杂度和空间复杂度的概述: 线性搜索(Linear Search) 起源:线性搜索是一种最基础的搜索算法,其起源可以追溯到计算机科学的早期。 原理:线性搜索逐一比较数据集中的每个元素,直到找 阅读全文
posted @ 2024-05-27 18:49
JackYang
阅读(352)
评论(0)
推荐(0)
摘要:
算法分类是一个广泛的主题,因为存在许多不同类型的算法,它们各自服务于不同的目的和领域。然而,以下是一些常见的算法分类方式: 基本算法分类: 搜索算法:如线性搜索、二分搜索、哈希搜索、深度优先搜索(DFS)、广度优先搜索(BFS)等。 排序算法:如冒泡排序、插入排序、选择排序、快速排序、归并排序、基数 阅读全文
posted @ 2024-05-27 18:41
JackYang
阅读(571)
评论(0)
推荐(0)
摘要:
基数排序(Radix Sort)起源或原理 基数排序(Radix Sort)是非比较型整数排序算法,其原理是将整数按位数切割成不同的数字,然后按每个位数分别比较。它按照从低位到高位(或者从高位到低位)依次对待排序的元素进行排序,直到所有的位数都被排序完毕。基数排序的思想借鉴了人类的计数排序法,即按照 阅读全文
posted @ 2024-05-27 18:39
JackYang
阅读(362)
评论(0)
推荐(0)
摘要:
原理 桶排序(Bucket Sort)是计数排序的升级版。它利用了函数的映射关系,将待排序的数据分散到有限数量的桶子里。每个桶子再个别排序(有可能再使用别的排序算法或是以递归方式继续使用桶排序进行排序)。桶排序是鸽巢排序的一种归纳结果。 定义 桶排序是分布式排序算法,将数据分到有限数量的桶子里。每个 阅读全文
posted @ 2024-05-27 17:41
JackYang
阅读(271)
评论(0)
推荐(0)
摘要:
计数排序(Counting Sort) 原理 计数排序(Counting Sort)的起源并不明确指向某一个特定的发明者或时间点,但它作为一种简单直观的排序算法,在计算机科学中得到了广泛的应用。计数排序的基本思想是通过统计数组中每个元素出现的次数,来确定其在排序后数组中的位置。 定义 计数排序是一种 阅读全文
posted @ 2024-05-27 16:30
JackYang
阅读(279)
评论(0)
推荐(0)
摘要:
堆排序(Heap Sort)起源 堆排序的概念由J.W.J. Williams在1964年提出,并在计算机科学中得到了广泛的应用。它利用了堆这种数据结构所具备的性质来实现排序。堆通常是一个可以被看做一棵完全二叉树的数组对象。 定义 堆排序(Heap Sort)是指利用堆这种数据结构所设计的一种排序算 阅读全文
posted @ 2024-05-27 15:18
JackYang
阅读(239)
评论(0)
推荐(0)
摘要:
快速排序(Quick Sort)起源 快速排序是由英国计算机科学家托尼·霍尔(Tony Hoare)在1960年提出的一种排序算法。它的基本思想是分治法(Divide and Conquer)的应用。 定义 快速排序是一种高效的排序算法,它采用分治法的策略,将一个大的数组分割成两个小的子数组,并使左 阅读全文
posted @ 2024-05-27 14:43
JackYang
阅读(428)
评论(0)
推荐(0)
摘要:
归并排序(Merge Sort) 起源 归并排序(Merge Sort)的算法是由约翰·冯·诺依曼(John von Neumann)在1945年提出的。但在实际的计算机编程中,归并排序通常被认为是由计算机科学家罗伯特·塞奇威克(Robert Sedgewick)在《算法》(Algorithms)一 阅读全文
posted @ 2024-05-27 14:23
JackYang
阅读(920)
评论(0)
推荐(0)
摘要:
前言 时间复杂度和空间复杂度是算法分析中非常重要的两个概念,它们分别用于衡量算法执行所需的时间和空间资源。 一、时间复杂度 定义: 时间复杂度是指执行算法所需要的计算工作量,它描述了算法运行时间与输入数据规模之间的关系。时间复杂度通常用大O符号(Big O notation)来表示,即O(f(n)) 阅读全文
posted @ 2024-05-27 13:30
JackYang
阅读(108)
评论(0)
推荐(0)