您的位置:

联动排序c语言,联动排序c语言是什么

本文目录一览:

c语言排序程序

#include stdio.h

void main()

{

int a[10];

int i,j,t;

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

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

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

for(j=i+1;j10;j++)

{

if(a[i]a[j])

{ /*交换从这里开始*/

t=a[i];

a[i]=a[j];

a[j]=t;}

} /*交换到这里结束*/

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

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

printf("\n");/*下一次循环时换行*/

}

也没有多大的错误

小心点,C是分语句执行的,到了“;”就是一条语句,除非你用“{}”,这样可以将几个语句合并为一条语句。可以简单这么理解。

c语言的两种排序?

1、选择排序法

要求输入10个整数,从大到小排序输出

输入:2 0 3 -4 8 9 5 1 7 6

输出:9 8 7 6 5 3 2 1 0 -4

代码:

#includelt;stdio.hgt;

int main(int argc,const char*argv[]){

int num[10],i,j,k,l,temp;

//用一个数组保存输入的数据

for(i=0;ilt;=9;i++)

{

scanf("%d",numlt;igt;);

}

//用两个for嵌套循环来进行数据大小比较进行排序

for(j=0;jlt;9;j++)

{

for(k=j+1;klt;=9;k++)

{

if(num[j]lt;num[k])//num[j]lt;num[k]

{

temp=num[j];

num[j]=num[k];

num[k]=temp;

}

}

}

//用一个for循环来输出数组中排序好的数据

for(l=0;llt;=9;l++)

{

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

}

return 0;

}

2、冒泡排序法

要求输入10个整数,从大到小排序输出

输入:2 0 3-4 8 9 5 1 7 6

输出:9 8 7 6 5 3 2 1 0-4

代码:

#includelt;stdio.hgt;

int main(int argc,const char*argv[]){

//用一个数组来存数据

int num[10],i,j,k,l,temp;

//用for来把数据一个一个读取进来

for(i=0;ilt;=9;i++)

{

scanf("%d",numlt;igt;);

}

//用两次层for循环来比较数据,进行冒泡

for(j=0;jlt;9;j++)

{

for(k=0;klt;9-j;k++)

{

if(num[k]lt;num[k+1])//num[k]lt;num[k+1]

{

temp=num[k];

num[k]=num[k+1];

num[k+1]=temp;

}

}

}

//用一个for循环来输出数组中排序好的数据

for(l=0;llt;=9;l++)

{

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

}

return 0;

}

扩展资料:

return 0代表程序正常退出。return是C++预定义的语句,它提供了终止函数执行的一种方式。当return语句提供了一个值时,这个值就成为函数的返回值。

return语句用来结束循环,或返回一个函数的值。

1、return 0,说明程序正常退出,返回到主程序继续往下执行。

2、return 1,说明程序异常退出,返回主调函数来处理,继续往下执行。return 0或return 1对程序执行的顺序没有影响,只是大家习惯于使用return(0)退出子程序而已。

c语言,数组排序,返回序号

思路:在数值进行排序时,下标也同时移动。这就要求二者要联动。为此创建一个PAIR结构体,将此二者关联在一起。用库里的快排函数qsort可以省略排序的麻烦,并指定qsort按PAIR中数值大小为标准排序结构体数组,这样排序结果中的结构体数组下标和值还是保持开始时的对应关系。

#includeSTDIO.H

#includestring.h

#includestdlib.h

#define N 8

typedef struct

{

int cj;//数值

int px;//下标

}PAIR;

//qsort的辅助比较函数

int compare(const void *p, const void *q)

{

PAIR t1= *(PAIR* )p;

PAIR t2= *(PAIR* )q;

return(t1.cjt2.cj);

}

int main()

{

PAIR a[N]={};

int cj[N]={};

int px[N]={};

printf("请输入%d个整数:", N);

for (int i=0;iN;i++)

{

scanf("%d",(a[i].cj));

a[i].px=i+1;

//数组

cj[i] = a[i].cj;

px[i] = a[i].px;

}

qsort((void *)a,N, sizeof(PAIR), compare);

printf("\n排好序的整数为:");

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

{

printf("%d ",a[i].cj);

cj[i]=a[i].cj;

}

printf("\n对应原来的下标:");

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

{

printf("%d ",a[i].px);

px[i] = a[i].px;

}

putchar('\n');

return 0;

}