c语言函数实现选择排序,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("%4d",a[i]);

}

}

程序改了很多,为什么?

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

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

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

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

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

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语言选择排序法

这是选择排序。先用a[0]与a[1]比较,当a[0]a[1]时并不交换,而用k记下来现在a[0]最小……这样一趟比较完后a[k]就是整个数组中最小的元素,把它与a[0]交换;第二趟,从a[1]开始重复前面的操作,那么最后a[1]就是剩下的n-1个元素中最小的……看a[0]、a[1]已经由小到大排好了,当做完n-1趟时不就把整个数组都排好了吗?注意:t=array[k];array[k]=array[i];array[i]=t;不是for(j=i+1;jn;j++)的循环体,要等它循环完了后才执行一次。

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语言 选择法排序

void sa(int array[],int n)

{

int i,j,k,temp;

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

{

k=i; //保存i的值,用k来进行循环排序

for(j=i+1;jn;j++) //将第i个元素后面的元素与第i个元素进行比较

if(array[j]array[k]) //如果第k=i个元素后面的元素小于i号元素,交换两个元素的标号, 这样就将最小元素的标号放到最前面

k=j; //交换标号

temp=array[k]; //循环结束后,交换两个标号下的元素的值

array[k]=array[i];

array[i]=temp;

}

}

这个程序实现的是由小到大的排序。第二个循环里面,就是i号元素后面最小的元素对应的标号放到k中,在交换当前元素与k号元素中的值,实现由大到小排序


网站名称:c语言函数实现选择排序,c语言 选择排序法
分享URL:http://scyanting.com/article/phgpgh.html