28,55,4,24,15,53,69,23,8 用简单选择排序算法
答案:1 悬赏:50 手机版
解决时间 2021-11-18 13:22
- 提问者网友:星軌
- 2021-11-18 02:36
28,55,4,24,15,53,69,23,8 用简单选择排序算法
最佳答案
- 五星知识达人网友:行雁书
- 2021-11-18 02:59
选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理是每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完。
数据:28,55,4,24,15,53,69,23,8,按从小到大排序过程是
第1趟排序结果为:
4 55 28 24 15 53 69 23 8
第2趟排序结果为:
4 8 28 24 15 53 69 23 55
第3趟排序结果为:
4 8 15 24 28 53 69 23 55
第4趟排序结果为:
4 8 15 23 28 53 69 24 55
第5趟排序结果为:
4 8 15 23 24 53 69 28 55
第6趟排序结果为:
4 8 15 23 24 28 69 53 55
第7趟排序结果为:
4 8 15 23 24 28 53 69 55
第8趟排序结果为:
4 8 15 23 24 28 53 55 69
最终排序结果为:
4 8 15 23 24 28 53 55 69
参考代码,C语言版本的
#include
#include
void swap(int*a,int*b)
{
int temp;
temp=*a;
*a=*b;
*b=temp;
}
void selectsort(int A[],int n)
{
register int i,j,min,m;
for(i=0;i {
min=i;//查找最小值
for(j=i+1;j {
if(A[min]>A[j])
{
min=j;
}
}
if(min!=i)
{
swap(&A[min],&A[i]);
printf("第%d趟排序结果为:
",i+1);
for(m=0;m {
if(m>0)
{
printf("");
}
printf("%d ",A[m]);
}
printf("
");
}
}
}
void main()
{
int a[9]={28,55,4,24,15,53,69,23,8},i;
selectsort(a,9);
printf("最终排序结果为:
");
for(i=0;i<9;i++)
{
if(i>0)
{
printf("");
}
printf("%d ",a[i]);
}
printf("
");
system("pause");
}
数据:28,55,4,24,15,53,69,23,8,按从小到大排序过程是
第1趟排序结果为:
4 55 28 24 15 53 69 23 8
第2趟排序结果为:
4 8 28 24 15 53 69 23 55
第3趟排序结果为:
4 8 15 24 28 53 69 23 55
第4趟排序结果为:
4 8 15 23 28 53 69 24 55
第5趟排序结果为:
4 8 15 23 24 53 69 28 55
第6趟排序结果为:
4 8 15 23 24 28 69 53 55
第7趟排序结果为:
4 8 15 23 24 28 53 69 55
第8趟排序结果为:
4 8 15 23 24 28 53 55 69
最终排序结果为:
4 8 15 23 24 28 53 55 69
参考代码,C语言版本的
#include
#include
void swap(int*a,int*b)
{
int temp;
temp=*a;
*a=*b;
*b=temp;
}
void selectsort(int A[],int n)
{
register int i,j,min,m;
for(i=0;i
min=i;//查找最小值
for(j=i+1;j
if(A[min]>A[j])
{
min=j;
}
}
if(min!=i)
{
swap(&A[min],&A[i]);
printf("第%d趟排序结果为:
",i+1);
for(m=0;m
if(m>0)
{
printf("");
}
printf("%d ",A[m]);
}
printf("
");
}
}
}
void main()
{
int a[9]={28,55,4,24,15,53,69,23,8},i;
selectsort(a,9);
printf("最终排序结果为:
");
for(i=0;i<9;i++)
{
if(i>0)
{
printf("");
}
printf("%d ",a[i]);
}
printf("
");
system("pause");
}
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯