c语言用函数选择排序 c语言使用函数的选择法排序

C语言:输入5个数,用调用函数的方法,从小到大排序 用简单点的#includestdio.h
void sort(float *a, int n)
{
int i,j,tmp;
for(i=0; in-1; i)
for(j=0; jn-i-1; j)
if(a[j]a[j 1])
{
tmp = a[j];
a[j] = a[j 1];
a[j 1] = tmp;
}
}
void main()
{
float a[5];
int i;
printf("请输入五个数(逗号隔开):");
scanf("%f,%f,%f,%f,%f",a[0],a[1],a[2],a[3],a[4]);
sort(a,5);
printf("排序后为:");
for(i=0; i5; i)
printf("%.2f ",a[i]);
printf("\n");
}
或者三个数的 。
void sort(int *a, int *b, int *c)
{
int tmp;
if(*a*b){
tmp = *b;
*b = *a;
*a = tmp;
}
if(*a*c){
tmp = *c;
*c = *a;
*a = tmp;
}
if(*b*c){
tmp = *c;
*c = *b;
*b = tmp;
}
return;
}
扩展资料:
C语言中没有预置的sort函数 。如果在C语言中,遇到有调用sort函数,就是自定义的一个函数,功能一般用于排序 。
一、可以编写自己的sort函数 。
如下函数为将整型数组从小到大排序 。void sort(int *a, int l)//a为数组地址 , l为数组长度 。
{
int i, j;
int v;//排序主体
for(i = 0; il - 1; i)
for(j = i 1; jl; j)
{
if(a[i]a[j])//如前面的比后面的大,则交换 。
{
v = a[i];
a[i] = a[j];
a[j] = v;
}
}
}
对于这样的自定义sort函数 , 可以按照定义的规范来调用 。
二、C语言有自有的qsort函数 。
功 能: 使用快速排序例程进行排序 。头文件:stdlib.h
原型:
void qsort(void *base,int nelem,int width,int (*fcmp)(const void *,const void *));
参数:
1、待排序数组首地址 。
2、数组中待排序元素数量 。
3、各元素的占用空间大小4 指向函数的指针,用于确定排序的顺序,这个函数必须要自己写比较函数,即使要排序的元素是int , float一类的C语言基础类型 。
C语言,用函数实现选择排序,对C纯菜鸟程序写得实在有点乱,变量名的声明与传递存在些问题,我帮你改改:
#include stdio.h
#define N 5
int a[N];
void init(void);
void compare(void);
void disp(void);
void main()
{
// printf("")
init();
compare();
void disp();
}
void init(void)
{
a[N]={2,1,4,9,5};
}
void compare(void)
{
int i,j,t;
for(i=0;iN;i)
for(j=i 1;jN;j)
if(a[i]a[j])
{
t=a[i];
a[i]=a[j]
a[j]=t;
}
}
void disp(void)
{
int i;
for(i=0;iN;i)
{
printf("M",a[i]);
}
}
程序改了很多,为什么?
数组a定义为局部变量,你传递了却没返回,这样使用不了,我改为了全局变量,这样不需要传递,直接使用就行 。
函数传递的另一个变量N不需要传递 , 因为本身N就是个全局变量,直接使用就行 。
还有一些定义了却没使用的变量我直接删了 。
你先编译运行一下,有错再回复 。
希望我的回答能帮助到你 。
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("排序之前的结果\n");
for(i = 0;i5;i)
printf("|%d|",TestData[i]);
int retData = https://www.04ip.com/post/SelectSort(TestData,5);
printf("排序之后的结果:\n");
for(i = 0;i5;i)
printf("|%d|",TestData[i]);
return 0;
}
4、简单选择排序中,需要移动的记录次数比较少,主要的时间消耗在对于数据的比较次数 。基本上,在比较的时候,消耗的时间复杂度为:n*n 。
用C语言编程:用选择法对10个整数排序,10个整数用scanf函数输入1、打开visual C6.0,准备一个空白的c语言文件,引入头文件,在main函数中定义变量和数组:
2、接下来用scanf函数输入的10个数,将输入的数存入到变量a中 , 接着进行比较排序,如果后一个数比前一个数大则利用中间变量t实现俩值互换 , 最后输出排序的结果:
3、编译运行程序,输入任意的10个数,回车后即可看到排序后的结果 。以上就是c语言中选择排序的用法:
c语言 , 使用函数的选择法排序void selectionsort(int a[],int m)
{
int i,j;
int k;
int tmp;
for(i = 0; im-1; i)//控制循环次数 , n个数需要n-1次循环
{
k = i;
for(j = i 1; jm ; j)
{
if(a[j]a[k])
k = j;
}
//i不等于k是就证明a[i]不是最小的,
//i等于k时证明a[i]就是本轮比较过程中最小的值
if(i != k)
{
tmp = a[i];
a[i] = a[k];
a[k] = tmp;
}
}
}
【c语言用函数选择排序 c语言使用函数的选择法排序】c语言用函数选择排序的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于c语言使用函数的选择法排序、c语言用函数选择排序的信息别忘了在本站进行查找喔 。

    推荐阅读