Algorithms_in_C++ 1.0.0
Set of algorithms implemented in C++.
|
[Wiggle Sort Algorithm] (https://leetcode.com/problems/wiggle-sort-ii/) Implementation More...
#include <algorithm>
#include <cassert>
#include <ctime>
#include <iostream>
#include <vector>
Namespaces | |
namespace | sorting |
for working with vectors | |
namespace | wiggle_sort |
Functions for Wiggle Sort algorithm. | |
Functions | |
template<typename T > | |
std::vector< T > | sorting::wiggle_sort::wiggleSort (const std::vector< T > &arr) |
Function used for sorting the elements in wave form. | |
template<typename T > | |
static void | displayElements (const std::vector< T > &arr) |
Utility function used for printing the elements. Prints elements of the array after they're sorted using wiggle sort algorithm. | |
static void | test () |
int | main () |
[Wiggle Sort Algorithm] (https://leetcode.com/problems/wiggle-sort-ii/) Implementation
Wiggle Sort sorts the array into a wave like array. An array ‘arr[0..n-1]’ is sorted in wave form, if arr[0] >= arr[1] <= arr[2] >= arr[3] <= arr[4] >= …..
std::vector< T > sorting::wiggle_sort::wiggleSort | ( | const std::vector< T > & | arr | ) |
Function used for sorting the elements in wave form.
Checking whether the even indexed elements are greater than their adjacent odd elements. Traversing all even indexed elements of the input arr. If current element is smaller than the previous odd element, swap them. If current element is smaller than the next odd element, swap them.
arr | input array (unsorted elements) |