代码拉取完成,页面将自动刷新
#include <stdlib.h>
#include <stdio.h>
void bin_insertSort(int array[], int n)
{
int i, j, temp, low, high, mid;
for(i = 1; i < n; ++i)
{
temp = array[i]; //将当前需要被插入元素保存在temp中
low = 0;
high = i - 1;
while(low <= high) //利用折半查找确定被插入元素array[i]的合适位置
{
mid = (low + high) / 2;
if(temp < array[mid])
high = mid - 1;
else
low = mid + 1;
}
for(j = i - 1; j >= low; --j) //找到合适位置low, 将[low, i-1]中的元素依次后移一位
array[j + 1] = array[j];
array[low] = temp; //插入元素array[i], 至此插入排序的一趟结束
}
}
int main()
{
int array[] = { 6, 3, 0, 6, 5, 8, 7, 4, 2, 7 };
int n = sizeof(array) / sizeof(int);
bin_insertSort(array, n);
for(int i = 0; i < n; ++i)
{
printf("%d ", array[i]);
}
printf("\n");
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。