面试篇算法:(一:排序算法)

一:冒泡排序

int[] a={2,5,3,7,4,8}

for(i=0;i<a.length;i++)
{
	for(j=0;j<a.length-i-1;j++)
	{
		if(a[j]>a[j+1])
		(
			int temp=a[j];
			a[j]=a[j+1];
			a[j+1]=temp;
		)
	}
}

原理:进行多次的比较,每次将最大的值选取出来,放在最后面。在进行多次比较。直至结果出来。

二:插入排序

int a[]={2,5,3,7,4,8};

for(i=1;i<a.length;i++)
(
	for(j=i;j>0;j--)
	(
		if (a[j]>a[j-1])
		{
			int t=a[j];
			a[j]=a[j-1];
			a[j-1]=t;
		}
		else
		{break;}
	)
)
思路:从第二个开始选择,和前一个进行比较,选择出合适他的位置,然后多次进行排序,得到最终的结果。

三:选择排序

int[] a={2,5,3,7,4,8}

for(i=0;i<a.length;i++)
{
	int k=i;
	for(j=k+1;j<=a.length-1-i;j++)
	{
		if(a[j]>a[k])
		k=j;
	}
	int temp=a[j];
	a[j]=a[k];
	a[k]=tmep;
}
原理:每次排序的时候,默认第一个为最大的值,然后和后面的进行相继比较。直到选出最大的那个值。然后将最大的值和本次比较的最后一个值进行替换,来选出本次最大的值。

四:快速排序

public class kuaipai{
public static paixu(int[] array,int low,int high)
	{
		int i,j,amy,t;
		if (low>high)
		{return;}
		i=low;
		j=high;
		amy=array[i];
		
		while(i<j)
			{
				if(array[j]>amy) else j--;

				if(array[i]<amy) else i++;
				
				t=array[j];
				array[j]=array[i];
				array[i]=t;
			}
		t=array[low];
		array[low]=array[i];
		array[i]=t;
		
		paixu( array, low, i-1);
		paixu( array, i+1,high);
	}
public satic void main(string[] args)
	{
		int array[]={2,5,3,7,4,8};
		paixu(array,0,a.length-1);
		for(i=0;i<a.length;1++)
		{
			system.out.print(array[i]);
		}
	}
}
思路:先分开,在进行左右对比,进行调换位置。

五:归并排序

public void mergeSort(int [] nums){
        mergeSortInternal(nums, 0, nums.length - 1);
    }

    public void mergeSortInternal(int[] nums, int start, int end){
        if(start >= end){
            return;
        }
        int mid = (start + end) / 2;
        mergeSortInternal(nums, start, mid);
        mergeSortInternal(nums, mid + 1, end);

        merge(nums, start, mid, end);
    }

    public void merge(int[] nums, int start, int mid, int end){
        int[] res = new int[end - start + 1];
        int i = start;
        int j = mid + 1;
        int index = 0;

        while(i <= mid && j <= end){
            if(nums[i] < nums[j]){
                res[index++] = nums[i++]; 
            }else{
                res[index++] = nums[j++];
            }
        }
        while(i <= mid){
            res[index++] = nums[i++];
        }
        while(j <= end){
            res[index++] = nums[j++];
        }

        for(int k = 0; k < res.length; k++){
            nums[start + k] = res[k];
        }
    }
    思路:先分开在合并。

你可能感兴趣的:(毕业,算法,排序算法,数据结构)