排序 2010-01-05 00:52:19 阅读2 评论0 字号:大中小
——————————————————————————————————————————————
直接选择:
#include<stdio.h>
int a[]={4,2,7,1,9,6};
int n=sizeof(a)/sizeof(int);
void main(void)
{
int i,j,min,temp;
for(i=0;i<n;i++){
min=i;
for(j=i+1;j<n;j++)
if(a[min]>a[j])min=j;
if(min!=i){
temp=a[i];
a[i]=a[min];
a[min]=temp;
}
}
for(i=0;i<n;i++)printf("%d ",a[i]);
printf("/n");
}
————————————————————————————————————————————
直接插入:
#include<stdio.h>
int a[]={2,7,3,9,4,6};
int n=sizeof(a)/sizeof(int);
void main(void)
{
int i,j;
int temp;
for(i=1;i<n;i++)
{
temp=a[i];
for(j=i-1;j>=0;j--)
{
if(temp>a[j])break;
a[j+1]=a[j];
}
if(j!=i-1)a[j+1]=temp;
}
直接选择:
#include<stdio.h>
int a[]={4,2,7,1,9,6};
int n=sizeof(a)/sizeof(int);
void main(void)
{
int i,j,min,temp;
for(i=0;i<n;i++){
min=i;
for(j=i+1;j<n;j++)
if(a[min]>a[j])min=j;
if(min!=i){
temp=a[i];
a[i]=a[min];
a[min]=temp;
}
}
for(i=0;i<n;i++)printf("%d ",a[i]);
printf("/n");
}
————————————————————————————————————————————
直接插入:
#include<stdio.h>
int a[]={2,7,3,9,4,6};
int n=sizeof(a)/sizeof(int);
void main(void)
{
int i,j;
int temp;
for(i=1;i<n;i++)
{
temp=a[i];
for(j=i-1;j>=0;j--)
{
if(temp>a[j])break;
a[j+1]=a[j];
}
if(j!=i-1)a[j+1]=temp;
}