青云博客 记录、分享

分布式算法 - Paxos算法

Paxos算法是一种用于分布式系统中实现一致性的算法。它通过引入提议者、接受者和学习者三个基本角色,在面对网络故障和节点故障的情况下,使得分布式系统能够就某个值达成一致。 Paxos算法的核心是通过多轮的消息交互来达成共识。提议者向接受者发送提议请求,接受者对提议进行投票,可以接受或拒绝。如果有足够

詹学伟 Published on 2024-04-24

安全算法 - 加密算法

加密算法是一种在信息安全领域中广泛应用的算法,能够将数据进行加密转换,以保证数据的保密性和安全性。 它具有保密性、对称加密和非对称加密、密钥管理、数据完整性和认证等重要特点和应用。 加密算法可以分为对称加密和非对称加密两种类型:

詹学伟 Published on 2024-04-24

分布式算法 - 雪花算法

雪花算法是一种用于生成全局唯一ID的分布式算法,用于解决分布式系统中生成唯一ID的需求。 雪花算法的核心思想是将生成的ID分为不同的部分,每个部分代表不同的含义。通常情况下,一个雪花 ID由3个部分组成: 时间戳:时间戳占用了ID的高位,精确到毫秒级别,可以根据时间戳来推测生成ID的时间。 机器节点

詹学伟 Published on 2024-04-24

分布式算法 - 一致性Hash算法

一致性哈希算法是一种分布式算法,用于解决数据分布和负载均衡问题。它通过将数据和节点映射到一个哈希环上,实现了数据在节点之间的均匀分布和最小化数据迁移。 一致性哈希算法的核心思想是将数据和节点都映射到哈希环上。每个节点在哈希环上有一个位置,根据哈希值进行排序。存储或查找数据时,通过哈希函数找到数据在环

詹学伟 Published on 2024-04-24

分布式算法 - Raft算法

Raft算法是一种用于分布式系统中实现一致性的算法,相对于Paxos算法更易理解和实现。它引入了领导者、跟随者和候选人的角色,通过心跳机制和选举过程来保持一致性。 在Raft算法中,节点可以是领导者、跟随者或候选人三种状态。领导者处理客户端请求并发送心跳信号,跟随者接受并响应心跳信号,而候选人则发起

詹学伟 Published on 2024-04-24

排序 - 快速排序

快速排序是一种高效的排序算法,基于分治思想。 它的核心思路是通过选择基准元素,将待排序数组划分为两个子数组,其中一个子数组的元素都小于基准元素,另一个子数组的元素都大于基准元素。然后对这两个子数组递归执行快速排序,最终得到整个数组有序。 具体实现步骤如下:选择一个基准元素作为比较目标,然后使用双指针

詹学伟 Published on 2024-04-24

算法思想 - 二分法

二分法是一种高效的算法思想,其主要思想是通过将待查找的数据集合逐渐缩小一半,来快速查找目标值或满足条件的解。与线性搜索相比,二分法具有时间复杂度更低的特点,是处理大规模数据时的必备技巧。 二分法的核心步骤包括确定搜索范围、计算中间值、比较与目标值的大小,然后根据比较结果更新搜索范围,循环执行直到找到

詹学伟 Published on 2024-04-24

算法思想 - 贪心算法

贪心算法是一种常用的求解最优化问题的算法思想。它通过每一步的局部最优选择,希望最终达到全局最优解。 贪心算法的核心思想是在求解过程中做出当前情况下的最优选择,并相信这个选择对全局来说也是最优的。它不考虑子问题的解决过程,只关注当前状态下的最优解。因此,贪心算法通常简单高效。 贪心算法的步骤相对简单明

詹学伟 Published on 2024-04-24

算法思想 - 回溯算法

回溯算法是一种通过回溯和递归的方式来解决问题的算法思想。回溯算法从问题初始状态开始,根据限制条件和约束条件,选择一个可行的路径进行搜索。如果搜索到的路径不满足条件,就会返回上一步,重新选择路径继续搜索,直到找到解或确定无解为止。 回溯算法通常用于具有多个选择路径,并需要依次尝试并验证每个选择的问题。

詹学伟 Published on 2024-04-24

算法思想 - 分治算法

分治算法是一种将复杂问题划分为规模较小的子问题,并递归地解决这些子问题,最后将它们的解合并为原问题的解的算法思想。 它具有以下几个关键步骤:分解、解决和合并。 通过将大问题分解为小问题,每个小问题都可以独立求解,然后将它们的解合并起来,最终得到原问题的解。 分治算法适用于具有重叠子问题性质的问题,能

詹学伟 Published on 2024-04-24
Previous Next