c语言函数选择排序,c语言中选择排序

C语言选择法排序

#includestdio.h

创新互联专业为企业提供娄星网站建设、娄星做网站、娄星网站设计、娄星网站制作等企业网站建设、网页设计与制作、娄星企业网站模板建站服务,十年娄星做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。

#define M 5

void main()

{

int b[M],i,j,t,k;

for(i=0;iM;i++)

scanf("%d",b[i]);

for(i=0;iM-1;i++)

{

for(k=i,j=i+1;jM;j++)

if(b[k]b[j])

k=j;

if(i!=k)

{

t=b[i];

b[i]=b[k];

b[k]=t;

}

}

for(i=0;iM;i++)

printf("%d ",b[i]);

}

错在大括号位置加错了。

扩展资料:

C语言选择排序详解

工作原理是每一次从无序组的数据元素中选出最小(或最大)的一个元素,存放在无序组的起始位置,无序组元素减少,有序组元素增加,直到全部待排序的数据元素排完。

以升序为例的图解:

代码:

#includestdio.h

void SelectionSort(int *num,int n)

{

int i = 0;

int min = 0;

int j = 0;

int tmp = 0;

for(i = 0;i n-1;i++)

{

min = i;//每次讲min置成无序组起始位置元素下标

for(j = i;j n;j++)//遍历无序组,找到最小元素。

{

if(num[min]num[j])

{

min = j;

}

}

if(min != i)//如果最小元素不是无序组起始位置元素,则与起始元素交换位置

{

tmp = num[min];

num[min] = num[i];

num[i] = tmp;

}

}

}

(此处空一行)

int main()

{

int num[6] = {5,4,3,2,9,1};

int i = 0;

SelectionSort(num,6);//这里需要将数列元素个数传入。有心者可用sizeof在函数内求得元素个数。

for(i = 0;i 6;i++)

{

printf("%d ",num[i]);

}

return 0;

}

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

void selectionsort(int a[],int m)

{

int i,j;

int k;

int tmp;

for(i = 0; i  m-1; i++)//控制循环次数,n个数需要n-1次循环

{

k = i;

for(j = i+1; j  m ; 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语言通过函数调用实现选择排序法:

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 = SelectSort(TestData,5);

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

for(i = 0;i5;i++)

printf("|%d|",TestData[i]);

return 0;

}

4、简单选择排序中,需要移动的记录次数比较少,主要的时间消耗在对于数据的比较次数。基本上,在比较的时候,消耗的时间复杂度为:n*n。

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("%4d",a[i]);

}

}

程序改了很多,为什么?

数组a 定义为局部变量,你传递了却没返回,这样使用不了,我改为了全局变量,这样不需要传递,直接使用就行。

函数传递的另一个变量N 不需要传递,因为本身N就是个全局变量,直接使用就行。

还有一些定义了却没使用的变量我直接删了。

你先编译运行一下,有错再回复。

希望我的回答能帮助到你。

大一C语言使用函数的选择法排序

if(p!=i)

{

q=a[p];

a[p]=a[i];

a[i]=q;

}

这一段放到前面的p=m;后地}后面。


分享标题:c语言函数选择排序,c语言中选择排序
URL地址:http://scyanting.com/article/hssesi.html