我在 c# 中开发了一个程序,它正在执行“插入排序”,代码获取元素的最大值和元素的值,然后一一显示排序值的步骤。
代码:
static void insertionSort(int[] ar)
{
for (int i = 1; i < ar.Length; i++)
{
int temp = ar[i];
int j = i - 1;
while (j >= 0 && ar[j] > temp)
{
ar[j + 1] = ar[j];
foreach (int val in ar)
Console.Write(val + " ");
Console.WriteLine();
j--;
}
}
}
static void Main(String[] args)
{
int ar_size;
ar_size = Convert.ToInt32(Console.ReadLine());
int[] ar = new int[ar_size];
for (int i = 0; i < ar_size; i++)
{
ar[i] = Convert.ToInt32(Console.Read());
}
insertionSort(ar);
Console.ReadKey();
}
我提供的示例输入:
5
2 4 6 8 3
输出:
谁能解释我为什么会这样!
任何帮助将不胜感激!:)