您的位置:首页 > 其它

选择排序---简单选择排序 堆排序

2017-04-27 20:42 316 查看
一、简单选择排序对于n个数要进行n次排序,第一次,将最小的数放在第一个。第二次,将第二小的树,放在第二个。。。。每次都和后面的数做比較,假设是从小到大的排序,当当前的数字比后面的大时,要进行交换。
#include <stdio.h>

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

}

}

void  main()
{
int i;
int a[] = {4,2,6,7,44,32,35,23};
int n = 8;
chosesort(a,n);
for(i =0;i<n;i++)
{
printf("%d ",a[i]);
}

}
二、堆排序堆是一棵全然二叉树。其每一个结点值都大于等于(小于等于)自己的左右孩子。把一个数量为n的数组,构成堆,则其根结点为最大值(最小值),然后再对剩下的n-1个数构成堆,继续取出其根结点。要完毕上述过程,须要完毕两个任务:1、将一些数字构成堆建堆方法:对初始序列建堆的过程,就是一个重复进行筛选的过程。1)n 个结点的全然二叉树。则最后一个结点是第n/2个结点的子树。2)筛选从第n/2个结点为根的子树開始,该子树成为堆。3)之后向前依次对各结点为根的子树进行筛选。使之成为堆,直到根结点。2、把根结点取出后,又一次构建堆把最后一个和根结点交换。用建堆的方式(仅仅须要对第一个数进行建堆排序),再对前n-1个数进行建堆。
#include <stdio.h>
/*
1、s为第s个须要调整的数。n为整个数组的长度
主要将每一个结点与孩子结点进行比較
*/void headadjust(int a[],int s,int n){int child,temp;temp = a[s];child = 2*s+1;while(child < n){//首先找到孩子中,大的那个if((child+1)<n && a[child+1]>a[child]){child++;}if(a[s]<a[child]){a[s] = a[child];s = child;child = 2*s+1;}else{break;}a[s] = temp;}}//每次建立堆,都将堆的根结点交换到最后,再用headadjust函数对第一个元素进行堆排序void heap(int a[],int length){int i,j,temp;for(i=(length-1)/2;i>=0;i--){headadjust(a,i,length);}for(j=length-1;j>=0;j--){temp = a[0];a[0] = a[j];a[j] = temp;headadjust(a,0,j);}}void main(){int i;int a[] = {3,1,5,7,2,4,9,6,10,8};int n=10;heap(a,n);for(i = 0;i<n;i++){printf("%d ",a[i]);}}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐