zoukankan      html  css  js  c++  java
  • 排序 二分插入法排序

    原文发布时间为:2009-03-06 —— 来源于本人的百度文章 [由搬家工具导入]

    using System;//二分插入排序
    namespace sorts
    {
       public class Class4
        {
           public static void Main()
           {
               int[] a = new int[] { 2, 12, 6, 5, 4, 3, 9 };
               BinSort(a);
               for (int i = 0; i < a.Length; i++)
                   Console.Write("{0} ", a[i]);
               Console.ReadLine();
           }

           public static void BinSort(int[] arr)
           {
               int left, right, mid, temp;

               for (int i = 1; i < arr.Length; i++)
               {
                   left = 0;
                   right = i - 1;
                   temp = arr[i];
                   while (left <= right)
                   {
                       mid = (left + right) >> 1;//(left + right)/2
                       if (temp < arr[mid]) //升序
                           right = mid - 1;
                       else
                           left = mid + 1;
                   }
                   for (int j = i - 1; j >= left; j--)
                       arr[j + 1] = arr[j];
                   arr[left] = temp;
               }
           }

        }
    }

  • 相关阅读:
    安装和配置SQL
    自定义中间件封装为模块
    留言板
    Spring Factories机制
    JVM参数配置
    全链路监控的方案概述与比较
    Lombok注解-@SneakyThrows
    @FeignClient注解 中属性 contextId使用
    @validate或@valid注解进行数据校验的解决方案
    maven的settings.xml标签详解
  • 原文地址:https://www.cnblogs.com/handboy/p/7153326.html
Copyright © 2011-2022 走看看