Category Trend  Published on 16/12/2023

QuickSort - Data Structure and Algorithm

Description

Quicksort is an efficient sorting algorithm based on the divide-and-conquer technique. This algorithm sorts an array by partitioning it. Here are some of the main steps of quicksort:

Pivot Selection:

  • The most important step in QuickSort is selecting the pivot element. An axis is an element that divides the array into two parts.
  • The middle element is often selected as the pivot, but some implementations use random or other methods.

Division:

  • After selecting the pivot, the array is divided into two parts, one smaller than the pivot and the other larger than the pivot.
  • Partitioning uses pointers, one that points to the beginning of the array and the other that points to the last element of the array.
  • The elements have to be arranged in the form of an axis.

Reversion:

  • Now the array has been divided into two parts. QuickSort is applied recursively to both parts.
  • Each part is divided into two parts by selecting a pivot, which is repeated until the array is sorted.

Combine:

  • When each part is sorted, they are merged, and the entire array is sorted.

The time complexity of QuickSort is O(n log n) in the average case, but can also be O(n^2) in the worst-case scenario, in which the pivot is always the minimum or maximum value of the array. But, its average performance is very high and it is usually used in sorting problems.

https://www.geeksforgeeks.org/quick-sort/

Thanks

Best Regards
Salesforce Developer Training
@rajatsharma0918


using System;
using cAlgo.API;
using cAlgo.API.Indicators;


// https://ctrader.com/users/profile/64575


namespace cAlgo.Indicators
{
    [Cloud("CCI", "CCI 2", FirstColor = "Blue", Opacity = 0.15, SecondColor = "Red")]
    [Indicator(IsOverlay = false, AccessRights = AccessRights.None)]
    public class CCiTrend : Indicator
    {
        [Output("CCI", LineColor = "Black")]
        public IndicatorDataSeries CCIa { get; set; }

        [Output("CCI 2", LineColor = "Black")]
        public IndicatorDataSeries CCIb { get; set; }

        [Output("Zero Line", Color = Colors.Black, LineStyle = LineStyle.Dots)]
        public IndicatorDataSeries ZeroLine { get; set; }

        [Output("Level +100", Color = Colors.Black, LineStyle = LineStyle.DotsRare)]
        public IndicatorDataSeries LevelPlus200 { get; set; }

        [Output("Level -100", Color = Colors.Black, LineStyle = LineStyle.DotsRare)]
        public IndicatorDataSeries LevelMinus200 { get; set; }


        [Parameter("CCi Period 1", DefaultValue = 21)]
        public int Period { get; set; }

        [Parameter("CCi Period 2", DefaultValue = 48)]
        public int Period2 { get; set; }


        private CommodityChannelIndex cci;
        private CommodityChannelIndex cci2;


        protected override void Initialize()
        {
            cci = Indicators.CommodityChannelIndex(Period);
            cci2 = Indicators.CommodityChannelIndex(Period2);
        }

        public override void Calculate(int index)
        {
            CCIa[index] = cci.Result[index];
            CCIb[index] = cci2.Result[index];
            
            ZeroLine[index] = 0;
            LevelPlus200[index] = 200;
            LevelMinus200[index] = -200;
        }
    }
}


rajatsharma0918's avatar
rajatsharma0918

Joined on 16.12.2023

  • Distribution: Free
  • Language: C#
  • Trading platform: cTrader Automate
  • File name: ig.algo
  • Rating: 0
  • Installs: 508
  • Modified: 16/12/2023 08:13
Comments
Log in to add a comment.
JI
jim.tollan · 1 year ago

argh… again, more clutter and non cTrader targetted rubbish…

moderators, please occasionally do a bit of erm, moderation. the uploads area is becoming a sh!tfest of rubbish due to a complete lack of oversight and supervised moderation.