C++ (Naive Partition Algorithm)朴素划分算法

目录

一种简单的数组分区方法

一些有趣的事实


如果您喜欢此文章,请收藏、点赞、评论,谢谢,祝您快乐每一天。

给定一个数组,任务是以最后一个元素为枢轴元素对数组进行分区。arr\[\]

数组的划分必须满足以下两个条件:

数组中小于或等于枢轴元素的元素排在枢轴元素之前。

数组中大于枢轴元素的元素会出现在枢轴元素之后。

**注意:**可能存在多个分区数组。

例如:

输入: arr\[\] = 5, 13, 6, 9, 12, 11, 8

输出: 5, 6, 8 , 13, 9, 12, 11

**说明:**所有小于枢轴元素 5, 6 的元素都排列在枢轴元素 5, 6 之前,所有大于枢轴元素 13, 9, 12, 11 的元素都排列在枢轴元素 13, 9, 12, 11 之后。

输入: arr\[\] = 4, 10, 9, 8, 16, 19, 9

输出: 4, 9, 8, 9 , 10, 16, 19

**说明:**所有小于或等于枢轴元素 4, 9, 8 的元素都排列在其前面,所有大于枢轴元素 10, 16, 19 的元素都排列在其后面。

一种简单的数组分区方法

一种简单的数组分区 方法是创建一个新的临时数组来存储重新排列后的元素。在这种方法中,我们首先遍历原始数组,并将所有小于或等于基准元素的元素添加到临时数组中。然后,我们将基准元素添加到临时数组中。最后,我们将大于基准元素 的元素填充到临时数组的剩余部分。

这样可以确保较小的元素位于枢轴* 元素之前,较大的元素位于枢轴元素之后。现在,将临时数组中的元素复制回原始数组。*

示例代码:

// C++ program to partition the array

// using naive partition approach

#include <iostream>

#include <vector>

using namespace std;

// Function to partition the array according

// to pivot index element

void partition(vector<int> &arr) {

int n = arr.size();

// Last element will be the pivot value

int pivot = arrn - 1;

// create a temp array to store the elements in order

vector<int> temp(n);

int idx = 0;

// First fill element smaller than or equal to

// pivot, into the temp array

for (int i = 0; i < n; i++) {

if (arri <= pivot)

tempidx++ = arri;

}

// Now fill the elements greater than pivot

for (int i = 0; i < n; i++) {

if (arri > pivot)

temp idx++ = arri;

}

// copy the elements from temp to arr

arr = temp;

}

int main() {

vector<int> arr = {5, 13, 6, 9, 12, 11, 8};

partition(arr);

for (int i = 0; i < arr.size(); i++)

cout << arri << " ";

return 0;

}

输出

5 6 8 13 9 12 11

时间复杂度: O(n),用于数组遍历;

辅助空间复杂度: O(n),因为它使用了临时数组。

一些有趣的事实

它是一种稳定的分区算法,这意味着它可以保持重复元素的相对顺序。我们可以通过使用它来使快速排序保持稳定。

它比其他分区算法慢,因为它需要多次遍历数组,并且需要额外的空间来存储元素。

我们可以通过交换第一个元素和最后一个元素,然后使用相同的代码,轻松地修改算法,将第一个元素(或任何其他元素)视为枢轴。

如果您喜欢此文章,请收藏、点赞、评论,谢谢,祝您快乐每一天。

相关推荐
地平线开发者1 分钟前
Conv+BN+Add+ReLU 融合机制简介
算法·自动驾驶
也曾看到过繁星9 分钟前
数据结构---顺序表
数据结构
yuanyuan2o211 分钟前
模型预训练:Hugging Face Transformers 基础
算法·ai·语言模型·自然语言处理·nlp·深度优先
杨充19 分钟前
1.3 浮点型数据设计灵魂
开发语言·python·算法
妄想出头的工业炼药师1 小时前
GS slam mono
算法·开源
meilindehuzi_a1 小时前
深入浅出数据结构:Python 字典(Dict)与集合(Set)的哈希表底层全链路追踪
数据结构·python·散列表
_日拱一卒1 小时前
LeetCode:207课程表
java·数据结构·算法·leetcode·职场和发展
郭涤生4 小时前
C++ 高性能编程最佳实践清单
开发语言·c++
用户987409238874 小时前
llamafactory 0.6.3 没有 llamafactory-cli
算法