Tag: algorithm

二叉树遍历

二叉树是一种树形数据结构,其中每个节点最多有两个子节点,分别称为左子节点和右子节点。遍历二叉树是一种访问所有节点的过程,主要有三种遍历方式:前序遍历、中序遍历和后序遍历。

分解质因数

分解质因数是将一个正整数分解为若干个质数的乘积的过程。每个质数都是一个素数,即只能被1和自身整除的数。

LRU算法简介

LRU(Least Recently Used)算法是一种缓存淘汰算法,常用于缓存系统中,通过保留最近使用的数据而淘汰最久未使用的数据,以提高缓存的命中率。LRU算法的核心思想是基于时间局部性原理:最近访问的数据在未来会被再次访问。

Paxos简介

Paxos算法背景

Leslie Lamport于1998年在他的论文《The Part-Time Parliament》中首次提出了Paxos算法,该算法旨在帮助分布式系统在面对网络分区、延迟和节点故障时,仍能达成一致。这个算法的名字来自希腊岛屿帕克索斯(Paxos),在那里传说中有个亚历克西斯(Alexis)与其他岛上的人达成了协议,这个故事与算法的设计目标密切相关。

Raft vs. Gossip

1. 概念对比

1.1 Raft中的关键概念

Raft 是一种为分布式系统设计的一致性算法,用于确保多个节点之间的数据达成一致。以下是 Raft 中的一些关键概念:

查找最大不重复子串的长度

查找最大不重复子串长度是一个常见的字符串处理问题,有多种解决思路。以下是几种常见的思路以及它们各自的时间和空间复杂度对比:

Raft 详解

1. Raft 简介

Raft 是一种共识算法,它确保在分布式系统中的多个节点之间达成一致性。Raft 的核心目标之一是保证数据在所有节点之间的同步。以下是 Raft 如何同步数据的主要步骤:

链表分组逆序

链表分组逆序是一个常见的操作,用于将链表按照一定规则分组后,逆序每个分组。这种操作常常用于解决链表中的某些问题。下面介绍几种常见的用于链表分组逆序的算法,并分析它们的优劣势:

查找数组中第K大的元素

要查找一个数组中的第 K 大元素,有多种方法可以实现,其中常用的方法是使用分治算法或快速选择算法,这两种方法的时间复杂度到时候O(n)。

深入分布式一致性:Raft 和 etcdRaft

分布式一致性是构建可靠的分布式系统的关键要素之一。为了确保数据的一致性和可用性,一致性算法的设计变得至关重要。在这篇博文中,我们将深入探讨两个与分布式一致性密切相关的主题:Raft 算法和 etcdRaft 存储系统。