## On the idea of algorithm

As the interview may require handwritten algorithm, I searched some information on the Internet and sorted out the OC implementation code of the following algorithm. Although it is not commonly used in normal development, more technical knowledge is still useful for future development

## Algorithmic text understanding and OC code implementation

### 1. Bubble sort algorithm

It is a "stable sorting algorithm" to exchange the positions of two adjacent elements in ascending or descending order

#### 1.1 online text theory

It is a simple and intuitive sorting algorithm. It repeatedly visits the sequence to be sorted, compares two elements at a time, and exchanges them if they are in the wrong order. The work of the visit sequence is repeated until there is no need to exchange, that is to say, the sequence has been sorted. The name of this algorithm comes from the fact that the smaller the element, the more slowly it will "float" to the top of the sequence through exchange.

As one of the simplest sorting algorithms, bubble sorting gives me the same feeling as Abandon's appearance in the word book, which is the first place on the first page every time, so I am most familiar with it. Another optimization algorithm of bubble sorting is to set up a flag. When elements are not exchanged in a sequence traversal, it is proved that the sequence is ordered. But this improvement has little effect on improving performance.

#### 1.2 algorithm steps

- Compare adjacent elements. If the first is bigger than the second, exchange them.
- Do the same for each pair of adjacent elements, from the first pair at the beginning to the last pair at the end. When this is done, the last element will be the maximum number.
- Repeat the above steps for all elements except the last one.
- Continue to repeat the above steps every time for fewer and fewer elements, until no one pair of numbers needs to be compared.

#### 1.3 dynamic diagram demonstration

#### 1.4 when is the fastest

When the input data is already in positive sequence.

#### 1.5 when is the slowest

When the input data is in reverse order.

#### 1.6 bubble sort code example

- (void)bubbleSortWithArray:(NSMutableArray *)array { for (int i = 0; i < array.count - 1; i++) { //Outer for loop control cycles for (int j = 0; j < array.count - 1 - i; j++) { //Inner layer for loop control switching times if ([array[j] integerValue] > [array[j + 1] integerValue]) { [array exchangeObjectAtIndex:j withObjectAtIndex:j + 1]; } } } }

### 2. Quick sort algorithm

Fast sorting of text and text understanding, and fast sorting through sentry station understanding

#### 2.1 online text understanding

Fast sorting is a sort algorithm developed by Tony hall. On average, n items should be sorted by Ο (nlogn) comparisons. In the worst case, a comparison of Ο (n2) times is required, but this is not common. In fact, fast sorting is usually significantly faster than other Ο (nlogn) algorithms, because its inner loop can be implemented efficiently in most architectures.

Fast sorting uses Divide and conquer strategy to divide a list into two sub lists.

Fast sorting is a typical application of divide and rule in sorting algorithm. In essence, fast sorting is a recursive divide and conquer method based on bubble sorting.

The name of quick sorting is simple and rough, because you know the meaning of the name as soon as you hear it, it is fast and efficient! It is one of the fastest sorting algorithms to process big data. Although the time complexity of Worst Case has reached O(n ²), others are excellent. In most cases, it is better than the sorting algorithm with the average time complexity of O(n logn), but I don't know why. Fortunately, my obsessive-compulsive disorder happened again. After searching many materials, I finally found a satisfactory answer in the "algorithm art and informatics competition": the worst operation of fast sorting is O(n ²), for example, fast sorting of sequence sequence. However, its expected time of equalization is O(nlogn), and the implicit constant factor in the O(nlogn) sign is very small, which is much smaller than the merging order with complexity stable equal to O(nlogn). Therefore, for the vast majority of random sequences with weak order, the fast sorting is always better than the merge sorting.

#### 2.2 algorithm steps

- Selecting an element from a sequence is called a pivot;
- Reorder the sequence, place all elements smaller than the benchmark value in front of the benchmark, and place all elements larger than the benchmark value behind the benchmark (the same number can be on either side). After the partition exits, the benchmark is in the middle of the sequence. This is called a partition operation;
- Recursively sorts the subsequences of the elements less than the reference value and the subsequences of the elements greater than the reference value;

The bottom case of recursion is that the size of the sequence is zero or one, which means it's always sorted. Although recursive, this algorithm always exits, because in each iteration, it will put at least one element to its last position.

#### 2.3 dynamic diagram demonstration

#### 2.4 quick sort code example

- (void)quickSortArray:(NSMutableArray *)array leftIndex:(NSInteger)left rightIndex:(NSInteger)right { if (left > right) { return; } NSInteger i = left; NSInteger j = right; //Record datum pivot NSInteger key = [array[i] integerValue]; while (i < j) { //First, start from the right j to find (from the rightmost to the left) the value smaller than the base number (key)<--- while (i < j && key <= [array[j] integerValue]) { j--; } //If the value [array[j] integerValue] searched from the right j is smaller than the reference number, then the small value searched will be swapped to the position of i if (i < j) { array[i] = array[j]; } //When a value smaller than the reference number is found from the right of i, the value larger than the reference number is found from i --- > while (i < j && [array[i] integerValue] <= key) { i++; } //If the value [array[i] integerValue] searched from the right of I to the right is larger than the reference number, then the large value searched is shifted to the position of j if (i < j) { array[j] = array[i]; } } //Put the reference number in the correct position, ---- change the position of the reference value (array subscript)--- array[i] = @(key); //Recursive sort //Reorder the numbers to the left of i [self quickSortArray:array leftIndex:left rightIndex:i - 1]; //Reorder the numbers to the right of i [self quickSortArray:array leftIndex:i + 1 rightIndex:right]; }

### 3. Select sort

Its improvement (compared with the bubbling algorithm) is: first, do not rush to change the position, first check one by one from A[0], see which number is the smallest, then write down the position P where the number is, wait until the lie down scanning is completed, and then adjust A[P] and A[0], then the smallest data in A[0] to A[n] is changed to the front position. Is an "unstable sorting algorithm"

It is a simple and intuitive sorting algorithm. No matter what data goes in, it is O(n? 2) time complexity. So when using it, the smaller the data size, the better. The only benefit might be that it doesn't take up extra memory.

#### Select Sorting Algorithm 1: direct select sort

#### 3.1 algorithm steps

- First, find the smallest (large) element in the unsorted sequence and store it at the beginning of the sorted sequence
- Then continue to find the smallest (largest) element from the remaining unsorted elements, and put it at the end of the sorted sequence.
- Repeat the second step until all elements are sorted.

#### 3.2 dynamic diagram demonstration

#### 3.3 directly select sorting sample code

- (void)selectSortWithArray:(NSMutableArray *)array { for (int i = 0; i < array.count; i++) { for (int j = i + 1; j < array.count; j++) { if (array[i] > array[j]) { [array exchangeObjectAtIndex:i withObjectAtIndex:j]; } } } }

#### Selection sorting algorithm 2: heap sort (which involves the concept of complete binary tree)

Heap sorting is a sort algorithm designed by using the data structure of heap. Stack is a structure of nearly complete binary tree, which satisfies the properties of stack at the same time: the key value or index of a child node is always less than (or greater than) its parent node. Heap sorting can be said to be a kind of selective sorting by using the concept of heap. There are two methods:

- Large top heap: the value of each node is greater than or equal to the value of its child nodes, which is used for ascending arrangement in heap sorting algorithm;
- Small top heap: the value of each node is less than or equal to the value of its child nodes, which is used for descending arrangement in heap sorting algorithm;

The average time complexity of heap sorting is Ο (nlogn).

#### Algorithm steps

- Create a heap H[0 n-1]；
- Swap the head (maximum) and tail;
- Reduce the heap size by 1 and call shift_down(0), the purpose is to adjust the data at the top of the new array to the corresponding position;
- Repeat step 2 until the heap size is 1.

#### Moving picture demonstration

#### Heap sort code example

- (void)heapSortWithArray:(NSMutableArray *)array { //Cycle build initial heap for (NSInteger i = array.count * 0.5; i >= 0; i--) { [self heapAdjustWithArray:array parentIndex:i length:array.count]; } //Perform n-1 cycles to complete sorting for (NSInteger j = array.count - 1; j > 0; j--) { //The last element and the first element are exchanged [array exchangeObjectAtIndex:j withObjectAtIndex:0]; //Filter the R[0] node and get the heap of i-1 nodes [self heapAdjustWithArray:array parentIndex:0 length:j]; NSLog(@"The first%ld Trip:", array.count - j); [self printHeapSortResult:array begin:0 end:array.count - 1]; } } - (void)heapAdjustWithArray:(NSMutableArray *)array parentIndex:(NSInteger)parentIndex length:(NSInteger)length { NSInteger temp = [array[parentIndex] integerValue]; //temp saves the current parent node NSInteger child = 2 * parentIndex + 1; //Get the left child first while (child < length) { //If there is a right child node and the value of the right child node is greater than the left child node, the right child node is selected if (child + 1 < length && [array[child] integerValue] < [array[child + 1] integerValue]) { child++; } //If the value of the parent node is greater than the value of the child node, it ends directly if (temp >= [array[child] integerValue]) { break; } //Assign the value of child node to parent node array[parentIndex] = array[child]; //Select the left child node of the child node and continue to filter down parentIndex = child; child = 2 * child + 1; } array[parentIndex] = @(temp); } - (void)printHeapSortResult:(NSMutableArray *)array begin:(NSInteger)begin end:(NSInteger)end { for (NSInteger i = 0; i < begin; i++) { } for (NSInteger i = begin; i <= end; i++) { } //Print heap sort NSLog(@"The heap sort ascending result is--->%@",array); }

### 4. Insert sort

#### 4.1 online text understanding

Although the code implementation of insertion sorting is not as simple and crude as bubble sorting and selection sorting, its principle should be the most easy to understand, because as long as people have played poker, they should be able to understand in seconds. Insertion sorting is the most simple and intuitive sorting algorithm. Its working principle is to build an ordered sequence. For unsorted data, scan the sorted sequence from the back to the front, find the corresponding position and insert it.

Like bubble sorting, insert sorting also has an optimization algorithm called split half insertion.

#### 4.2 algorithm steps

- The first element of the first sequence to be sorted is regarded as an ordered sequence, and the second element to the last element is regarded as an unsorted sequence.
- Scan the unsorted sequence from beginning to end, and insert each element scanned into the appropriate position of the ordered sequence. (if the element to be inserted is equal to an element in an ordered sequence, insert the element to be inserted after the equivalent element)

#### 4.3 dynamic diagram demonstration

#### 4.4 insert sort code example

- (void)insertSortWithArray:(NSMutableArray *)array { NSInteger j; for (NSInteger i = 1; i < array.count; i++) { //Take out every data to be inserted and start to search from array[1] NSInteger temp = [array[i] integerValue]; for (j = i - 1; j >= 0 && temp < [array[j] integerValue]; j--) { //If the previous number is larger than temp, move the number back one place, leaving room for temp to insert, similar to finishing playing cards [array[j + 1] integerValue] = [array[j] integerValue]]; array[j] = [NSNumber numberWithInteger:temp]; } } }

## Merge sort, Hill sort, cardinal sort, bucket sort and count sort are not commonly used algorithms. They are advanced algorithms. Do novices think they can only understand the text? The specific text theory and implementation principle need to be further studied. Many materials are collected on the Internet and they say that they need to master several commonly used algorithms, such as bubbling, fast, inserting and selecting Enough, I think it's better to have more technology and better technology. Of course, the premise is to have a good command of it. It's the best to be able to write and speak the truth. Otherwise, it's all temporary memory. Well, what I understand at present is not deep enough. I'd better take some notes on the Internet. I can also copy and study them, so that I can digest the algorithms commonly used by computers in the future

As a developer, it is particularly important to have a learning atmosphere and a communication circle. This is my iOS communication group: 519832104 Whether you are Xiaobai or Daniel, welcome to join us, share experience, discuss technology, and let's learn and grow together!

In addition, a copy of interview questions collected by all friends is attached. If you need iOS development learning materials and real interview questions, you can add advanced iOS development communication group, which can be downloaded by yourself!

Click here to exchange and learn with iOS Daniel now

### 5. Merge sort

#### 5.1 online text understanding

Merge sort is an effective sort algorithm based on merge operation. This algorithm is a typical application of Divide and Conquer.

As a typical algorithm application of the idea of divide and rule, there are two ways to realize the merging and sorting:

- Top down recursion (all recursive methods can be rewritten by iteration, so there is the second method);
- Bottom up iteration;

In "JavaScript description of data structure and algorithm", the author gives a bottom-up iterative method.

Like selection sorting, the performance of merge sorting is not affected by the input data, but the performance is much better than selection sorting, because it is always the time complexity of O(nlogn). The cost is extra memory.

#### 5.2 algorithm steps

- The application space is the sum of two sorted sequences, which is used to store the merged sequences;
- Set two pointers, and the initial positions are the starting positions of two sorted sequences respectively;
- Compare the elements pointed by the two pointers, select the relatively small elements to put into the merge space, and move the pointer to the next position;
- Repeat step 3 until a certain pointer reaches the end of the sequence;
- Copy all remaining elements of another sequence directly to the end of the merge sequence.

#### 5.3 dynamic diagram demonstration

#### 5.4 example of merge sort code

//Top down merge sort /** Recursively use merge sort to sort the range of array[left...right] @param array array @param left Left border @param right Right border */ - (void)mergeSortWithArray:(NSMutableArray *)array left:(NSInteger)left right:(NSInteger)right { //Judge the recursion to the end if (left >= right) { //In this case, there is only one element or it does not exist return; } //Location of intermediate index NSInteger middle = (right + left) / 2; //Sort the elements of the left middle interval [self mergeSortWithArray:array left:left right:middle]; //Sort the elements of middle + 1 -- right [self mergeSortWithArray:array left:middle + 1 right:right]; //Merge after sorting of both sides [self mergeSortWithArray:array left:left middle:middle right:right]; } /** Merge the two intervals of [left middle] and [middle + 1 right] @param array Array passed in @param left Left border @param middle Middle position @param right Right border */ - (void)mergeSortWithArray:(NSMutableArray *)array left:(NSInteger)left middle:(NSInteger)middle right:(NSInteger)right { //Copy an array NSMutableArray *copyArray = [NSMutableArray arrayWithCapacity:right - left + 1]; for (NSInteger i = left; i <= right; i++) { //Note that there is an offset of left, so the left should be subtracted when copyArray is assigned copyArray[i - left] = array[i]; } NSInteger i = left, j = middle + 1; //The loop starts from the left to reassign the array in the right interval. Note that the assignment starts from the left too. Don't get used to writing it as starting from 0, and it's all closed intervals for (NSInteger k = left; k <= right; k++) { //When the left boundary exceeds the middle point, it means that the left half of the array is beyond the boundary and the first element of the array directly taking the right part is enough if (i > middle) { //Assign values to the array. Note the offset left because it starts from left array[k] = copyArray[j - left]; //Index++ j++; } else if (j > right) {//When j is larger than the right boundary, it is proved that half of the array is out of bounds. Just take the first element of the left half directly array[k] = copyArray[i - left]; //Index++ i++; } else if (copyArray[i - left] > copyArray[j - left]) {//Left and right half array comparison //When the first element of the right half of an array takes hours, assign the array the first element of the right half array[k] = copyArray[j - left]; //Right half index plus 1 j++; } else {//The first element of the right half array is larger than the first element of the left half array array[k] = copyArray[i - left]; i++; } } }

### 6. Shell sort

#### 6.1 online text understanding

Hill sort, also known as descending incremental sort algorithm, is a more efficient version of insertion sort. But Hill sorting is an unstable sorting algorithm.

Hill's ranking is based on the following two properties of insertion ranking

- The efficiency of insert sorting is high when it is used to sort almost sorted data, that is to say, it can achieve the efficiency of linear sorting;
- But insertion sorting is generally inefficient, because insertion sorting can only move data one bit at a time;

The basic idea of hill sorting is: first, the whole record sequence to be sorted is divided into several subsequences for direct insertion sorting, and then when the records in the whole sequence are "basically ordered", all records are inserted and sorted in sequence.

#### 6.2 algorithm steps

- Select an incremental sequence t1, t2 , tk, where ti > TJ, tk = 1;
- By the number k of incremental sequence, the sequence is sorted by K times;
- According to the corresponding increment ti, the sequence to be sorted is divided into several subsequences with length of m, and each subsequence is inserted and sorted directly. Only when the increment factor is 1, the whole sequence is treated as a table, and the table length is the length of the whole sequence.

#### 6.4 example of Hill sort code

- (void)shellAscendingOrderSort:(NSMutableArray *)ascendingArr { NSMutableArray *buckt = [self createBucket]; NSNumber *maxnumber = [self listMaxItem:ascendingArr]; NSInteger maxLength = numberLength(maxnumber); for (int digit = 1; digit <= maxLength; digit++) { // Into the barrel for (NSNumber *item in ascendingArr) { NSInteger baseNumber = [self fetchBaseNumber:item digit:digit]; NSMutableArray *mutArray = buckt[baseNumber]; [mutArray addObject:item]; } NSInteger index = 0; for (int i = 0; i < buckt.count; i++) { NSMutableArray *array = buckt[i]; while (array.count != 0) { NSNumber *number = [array objectAtIndex:0]; ascendingArr[index] = number; [array removeObjectAtIndex:0]; index++; } } } NSLog(@"Hill sort results in ascending order:%@", ascendingArr); } - (NSMutableArray *)createBucket { NSMutableArray *bucket = [NSMutableArray array]; for (int index = 0; index < 10; index++) { NSMutableArray *array = [NSMutableArray array]; [bucket addObject:array]; } return bucket; } - (NSNumber *)listMaxItem:(NSArray *)list { NSNumber *maxNumber = list[0]; for (NSNumber *number in list) { if ([maxNumber integerValue] < [number integerValue]) { maxNumber = number; } } return maxNumber; } NSInteger numberLength(NSNumber *number) { NSString *string = [NSString stringWithFormat:@"%ld", (long)[number integerValue]]; return string.length; } - (NSInteger)fetchBaseNumber:(NSNumber *)number digit:(NSInteger)digit { if (digit > 0 && digit <= numberLength(number)) { NSMutableArray *numbersArray = [NSMutableArray array]; NSString *string = [NSString stringWithFormat:@"%ld", [number integerValue]]; for (int index = 0; index < numberLength(number); index++) { [numbersArray addObject:[string substringWithRange:NSMakeRange(index, 1)]]; } NSString *str = numbersArray[numbersArray.count - digit]; return [str integerValue]; } return 0; }

### 7. Radix sort

#### 7.1 text understanding

Radix sorting is a non comparative integer sorting algorithm. Its principle is to cut the integer into different numbers according to the number of digits, and then compare them according to each digit. Because integers can also express strings (such as names or dates) and floating-point numbers of a specific format, cardinal sorting is not only used for integers.

#### 7.2 Radix sorting vs count sorting vs bucket sorting

There are two ways to sort cardinality:

These three sorting algorithms all use the concept of bucket, but there are obvious differences in the use of bucket:

- Cardinality sorting: allocate buckets according to each number of key values;
- Count sorting: each bucket only stores one key value;
- Bucket sorting: each bucket stores a certain range of values;

#### 7.3 dynamic diagram demonstration

#### 7.4 example of cardinality sort code

- (void)radixAscendingOrderSort:(NSMutableArray *)ascendingArr { NSMutableArray *buckt = [self createBucket]; NSNumber *maxnumber = [self listMaxItem:ascendingArr]; NSInteger maxLength = numberLength(maxnumber); for (int digit = 1; digit <= maxLength; digit++) { // Into the barrel for (NSNumber *item in ascendingArr) { NSInteger baseNumber = [self fetchBaseNumber:item digit:digit]; NSMutableArray *mutArray = buckt[baseNumber]; [mutArray addObject:item]; } NSInteger index = 0; for (int i = 0; i < buckt.count; i++) { NSMutableArray *array = buckt[i]; while (array.count != 0) { NSNumber *number = [array objectAtIndex:0]; ascendingArr[index] = number; [array removeObjectAtIndex:0]; index++; } } } NSLog(@"Sorting results in ascending cardinality:%@", ascendingArr); }

### 8. Counting sort

#### 8.1 text understanding

The core of count sorting is to convert the input data values into keys and store them in the extra array space. As a sort of linear time complexity, count sort requires that the input data must be an integer with a certain range.

#### 8.2 dynamic diagram demonstration

### 9. Bucket sort

#### 9.1 text understanding

Bucket sorting is an upgrade of count sorting. It makes use of the mapping relation of the function. The key to its efficiency lies in the determination of the mapping function. In order to make bucket sorting more efficient, we need to do these two things:

- Increase the number of barrels as much as possible with sufficient additional space
- The mapping function can evenly distribute the input N data into K buckets

At the same time, for the sorting of elements in buckets, it is very important to choose which sort algorithm to compare.

#### 9.2 when is the fastest

When the input data can be evenly distributed to each bucket.

#### 9.3 when is the slowest

When the input data is allocated to the same bucket.