数据结构学习【各种排序算法代码实现】
#include <iostream>
#include <math.h>
#include <queue>
using namespace std;
void StraightInsertSort(int a[],int n){
int temp,i,j;
for(i=1;i<n;i++){
if(a[i]<a[i-1]){
temp=a[i],j;
for(j=i-1;a[j]>temp&&j>=0;j--)
a[j+1]=a[j];
a[j+1]=temp;
}
}
}
void BinaryInsertSort(int a[],int n){
int i,j,low,high,mid,temp;
for(i=1;i<n;i++){
temp=a[i];
low=0;high=i-1;
while(low<=high){
mid=(low+high)/2;
if(a[mid]>temp) high=mid-1;
else low=mid+1;
}
for(j=i-1;j>=low;j--)
a[j+1]=a[j];
a[low]=temp;
}
}
void ShellSort(int a[],int n){
int d,i,j,temp;
for(d=n/2;d>=1;d=d/2){
for(i=d;i<n;i++){
if(a[i]<a[i-d]){
temp=a[i];
for(j=i-d;j>=0&&temp<a[j];j-=d)
a[j+d]=a[j];
a[j+d]=temp;
}
}
}
}
void SimpleSelectSort(int a[],int n){
int i,j,min,temp;
for(i=0;i<n-1;i++){
min=i;
for(j=i+1;j<n;j++){
if(a[j]<a[min]) min=j;
}
if(min!=i){
temp=a[i];
a[i]=a[min];
a[min]=temp;
}
}
}
void HeapAdjust(int a[],int k,int len){
int temp=a[k];
for(int i=2*k+1;i<len;i=2*i+1){
if(i+1<len&&a[i]<a[i+1])
i++;
if(temp>=a[i]) break;
else{
a[k]=a[i];
k=i;
}
}
a[k]=temp;
}
void BuildMaxHeap(int a[],int len){
for(int i=len/2-1;i>=0;i--)
HeapAdjust(a,i,len);
}
void HeapSort(int a[],int len){
BuildMaxHeap(a,len);
for(int i=len-1;i>=1;i--){
int temp=a[0];
a[0]=a[i];a[i]=temp;
HeapAdjust(a,0,i);
for(int i=0;i<=6;i++)
printf("%d ",a[i]);
printf("\n");
}
}
void BubbleSort(int a[],int len){
for(int i=0;i<len-1;i++){
bool flag=false;
for(int j=len-1;j>i;j--){
if(a[j-1]>a[j]){
int temp=a[j];
a[j]=a[j-1];a[j-1]=temp;
flag=true;
}
}
if(flag==false)
return;
}
}
int partition(int a[],int low,int high){
int pivot=a[low];
while (low<high){
while (low<high&&a[high]>=pivot) --high;
a[low]=a[high];
while (low<high&&a[low]<=pivot) ++low;
a[high]=a[low];
}
a[low]=pivot;
return low;
}
void QuickSort(int a[],int low,int high){
if(low<high){
int pivot=partition(a,low,high);
QuickSort(a,low,pivot-1);
QuickSort(a,pivot+1,high);
}
}
int n=7;
int *b=(int *)malloc(n*sizeof(int));
void Merge(int a[],int low,int mid,int high){
int i,j,k;
for(k=low;k<=high;k++)
b[k]=a[k];
for(i=low,j=mid+1,k=i;i<=mid&&j<=high;k++){
if(b[i]<=b[j])
a[k]=b[i++];
else
a[k]=b[j++];
}
while(i<=mid) a[k++]=b[i++];
while(j<=high) a[k++]=b[j++];
}
void MergeSort(int a[],int low,int high){
if(low<high){
int mid=(low+high)/2;
MergeSort(a,low,mid);
MergeSort(a,mid+1,high);
Merge(a,low,mid,high);
}
}
void RadixSort(int a[],int length,int n){
queue<int> q[10];
for(int i=0;i<n;i++){
for(int j=0;j<length;j++){
q[(a[j]%(int)pow(10,i+1))/(int)pow(10,i)].push(a[j]);
}
int count=0;
for(int j=0;j<10;j++){
while(!q[j].empty()){
a[count++]=q[j].front();
q[j].pop();
}
}
}
}
int main(){
int a[]={
4,5,6,2,34,7,1};
RadixSort(a,7,2);
for(int i=0;i<=6;i++)
printf("%d ",a[i]);
system("pause");
}