永发信息网

c语言怎样通过函数调用实现选择排序法

答案:3  悬赏:40  手机版
解决时间 2021-11-25 10:08
c语言怎样通过函数调用实现选择排序法
最佳答案
c语言通过函数调用实现选择排序法:
1、写一个简单选择排序法的函数名,包含参数。int SelectSort(int * ListData,int ListLength);
2、写两个循环,在循环中应用简单选择插入排序:
int SelectSort(int * ListData,int ListLength)
{
int i , j ;
int length = ListLength;
for(i=0;i<=length-2;i++)
{
int k = i;
for(j=i+1;j<=length-1;j++)
{
if(ListData[k]>ListData[j])
{
k=j;
}
}  
if(k!=i)
{
int tmp = ListData[i];
ListData[i] = ListData[k];
ListData[k] = tmp;
}
}


return 0;
}

3、对编好的程序进行测试,得出测试结果:
int main()
{
int TestData[5] = {34,15,6,89,67};
int i = 0;


printf("排序之前的结果
");

for(i = 0;i<5;i++)
printf("|%d|",TestData[i]);
int retData = SelectSort(TestData,5);

printf("排序之后的结果:
");

for(i = 0;i<5;i++)
printf("|%d|",TestData[i]);
return 0;
}

4、简单选择排序中,需要移动的记录次数比较少,主要的时间消耗在对于数据的比较次数。基本上,在比较的时候,消耗的时间复杂度为:n*n。
全部回答
#include
main()
{
int a[10],i,j,t;
for(i=0;i<10;i++)
scanf("%d",&a[i]);
for(i=0;i<9;i++)
{
for(j=i+1;j<10;j++)
if(a[j] {
t=a[j];
a[j]=a[j+1];
a[j+1]=t;
}
}
for(i=0;i<10;i++)
printf("%5d",a[i]);
printf("\n");
}
楼上那个是冒泡:

#include

void selection_sort(int a[], int n)
{
int i, j, k;
for(i = 0; i < n; ++i)
{
k = i;
for(j = i + 1; j < n; ++j)
if(a[k] >= a[j])
k = j;
j = a[i];
a[i] = a[k];
a[k] = j;
}
}

int main()
{
int a[] = {3,6,1,2,9,5,4,7,0,8}, i;

selection_sort(a, 10);

for(i = 0; i < 10; ++i)
printf("%d ", a[i]);

return 0;
}
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
女朋友跟我分手后我跟她聊的,大家看一看还有
种菠菜怎样浇水
盘中餐食用油是非转基因的吗?
出口产品出现质量问题,工厂却逃避并推卸责任
欧林斯家具怎么样
小白求教B150的主板是技嘉的D3H好还是华擎K4
说一个人爱慕虚荣是什么意思
美国X档案BD中英双字1024高清种子下载地址有
注塑机射不岀胶,可以熔胶,pom料,熔胶的时
---Would you like coffee or tea?---I pref
魔鬼是掌管什么的?但神又是掌管什么的?
win10安装分析家2006
开淘宝店,怎么让别人更容易搜到你的店,宝贝
jack今天在学校丢了一块蓝色的手表,他的电话
为什么古代的女人要把眉毛刮掉?
推荐资讯
买房,总共22层,买在19层好,还是16层好?或
森海塞尔IE800和索尼XBA-Z5哪个值得买(从价
樊羽女装怎么样好不好,我想加盟有没有人知道
薄层色谱时,展开剂极性小会产生什么现象
摩力圣汇的客房价格贵吗?
尉氏县水坡乡联合中学地址在哪,我要去那里办
小麦被蝼蛄咬怎麽办
联想k410为什么登网页会黑屏?
洛阳的()香港的()澳门的()广州的()市
什么地方有卖天霸手表的
下列各式中,正确的角度互化是(  )A.63.
关闭了微信怎么打开自己关闭徽信重新打开怎么
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?