zoukankan      html  css  js  c++  java
  • 直接插入排序

    java版本

    /*************************************************************************
        > File Name: DirectInsertSort.java
        > Author: lxlm
        > Created Time: 2016年04月27日 星期三 20时21分35秒
     ************************************************************************/
    
    public class DirectInsertSort
    {
        public static void main(String[] args)
        {
            int[] a={6,1,2,7,9,3,4,5,10,8};
            directInsertSort(a);
            printArray(a);
        }
        public static void directInsertSort(int[] a)
        {
            int temp = 0;
            int n = a.length;
            int j;
            if(n==1 || n==0)
            {
                return;
            }
            for(int  i=1;i<n;i++)
            {
                temp = a[i];
                for(j=i-1;j>=0 && temp<a[j];)//注意:必须将j>=0放在temp<a[j]前面
                {
                    a[j+1] = a[j];
                    --j;
                }
                a[j+1] = temp;
            }
        }
    
        public static void printArray(int[] a)
        {   
            for(int item:a)
            {
                System.out.printf("%d	",item);
            }
            System.out.println();
        }
    }

    C版本

    /*************************************************************************
        > File Name: directInsertSort.c
        > Author: lxm
        > Created Time: 2016年04月27日 星期三 20时10分14秒
     ************************************************************************/
    
    #include<stdio.h>
    
    #define N 10
    
    void directInsertSort(int* a, int n);
    void printArray(int* a, int n);
    int main(void)
    {
        int a[] = {6,1,2,7,9,3,4,5,10,8};
        directInsertSort(a,N);
        printArray(a,N);
        return 0;
    }
    
    void directInsertSort(int* a, int n)
    {
        int i,j;
        int temp;
        for(i=1;i<n;i++)
        {
            temp = a[i] ;
            for(j=i-1;j>=0 && temp<a[j];)
            {
                a[j+1] =a[j];
                j--;
            }
            a[j+1]=temp ;   
        }
    }
    
    
    void printArray(int* a, int n)
    {
        int i;
        for(i=0;i<n;i++)
        {
            printf("%d	",a[i]);
        }
        printf("
    ");
    }
    
    
  • 相关阅读:
    7.3---直线是否相交(CC150)
    7.2---蚂蚁相遇问题(CC150)
    5.6---交换整数的奇数位和偶数位(CC150)
    5.5---整数A转成整数B(CC150)
    5.2---小数的二进制表示(CC150)
    5.1---二进制数插入(CC150)
    4.6---找二叉树中序后继(CC150)
    4.5---判断是否是二叉排序树BST(CC150)
    4.4---建立二叉树的链表
    linux中查看java进程
  • 原文地址:https://www.cnblogs.com/yldf/p/11900175.html
Copyright © 2011-2022 走看看