using System.Collections.Generic;
static public void DoMerge(int[] numbers, int left, int mid, int right)
int[] temp = new int[25];
int i, left_end, num_elements, tmp_pos;
num_elements = (right - left + 1);
while ((left <= left_end) && (mid <= right))
if (numbers[left] <= numbers[mid])
temp[tmp_pos++] = numbers[left++];
temp[tmp_pos++] = numbers[mid++];
temp[tmp_pos++] = numbers[left++];
temp[tmp_pos++] = numbers[mid++];
for (i = 0; i < num_elements; i++)
numbers[right] = temp[right];
static public void MergeSort_Iterative(int[] numbers, int left, int right)
List<MergePosInfo> list1 = new List<MergePosInfo>();
List<MergePosInfo> list2 = new List<MergePosInfo>();
list1.Insert(list1.Count, info);
mid = (right + left) / 2;
list2.Insert(list2.Count, info2);
list1.Insert(list1.Count, info);
list1.Insert(list1.Count, info);
for (int i = 0; i < list2.Count; i++)
DoMerge(numbers, list2[i].left, list2[2].mid, list2[2].right);
public static void Main()
3, 8, 7, 5, 2, 1, 9, 6, 4
Console.WriteLine("MergeSort By Iterative Method");
MergeSort_Iterative(numbers, 0, len - 1);
for (int i = 0; i < 9; i++)
Console.WriteLine(numbers[i]);