C语言中用三个函数排序 c语言中几种排序方法
编写c语言程序用三个函数求10个同学的平均分及成绩排序
1、写一个主函数,10个成绩放在一个数组里。
创新互联建站专注于汝州企业网站建设,响应式网站,购物商城网站建设。汝州网站建设公司,为汝州等地区提供建站服务。全流程定制制作,专业设计,全程项目跟踪,创新互联建站专业和态度为您提供的服务
2、然后写一个求平均值的函数,返回平均值,用循环语句求和在求平均值,小学生应该都会求平均值。
3、再写一个排序算法,先模仿一个冒泡排序算法,最简单的排序算法。
这样不就三个函数了吗?,这个题主要让你初步掌握,数组,循环语句的使用,函数的调用,函数参数的传递,函数值的返回等。学习C就自己多练,多想这样会进步,代码就不写了吧,对你不好。
C语言中要把三个数从大到小排列出来应该怎么编?
初学简单版本代码如下:
#includestdio.h
int main( )
{
int a, b, c;//定义三个数的变量
int t ;//定义作为交换的变量
scanf ( "%d%d%d" , a, b, c ) ; //取值
if ( a b )
{t = a; a = b; b = t ;};//如果a,b,进行交换,反之不动
if ( a c )
{t = a; a = c; c = t ;};//同上
if ( b c )
{t = b; b = c; c = t ;};
printf( "%-5d%-5d%-5d\n" , a, b, c);//输出
}
扩展资料:
C语言中其他多个数排序的方法:
1、冒泡排序法
#include stdio.h
#define SIZE 8
void bubble_sort(int a[], int n);
void bubble_sort(int a[], int n)
{
int i, j, temp;
for (j = 0; j n - 1; j++)
for (i = 0; i n - 1 - j; i++)
{
if(a[i] a[i + 1])
{
temp = a[i];
a[i] = a[i + 1];
a[i + 1] = temp;
} } }
int main()
{
int number[SIZE] = {95, 45, 15, 78, 84, 51, 24, 12};
int i;
bubble_sort(number, SIZE);
for (i = 0; i SIZE; i++)
{
printf("%d\n", number[i]);
}
}
2、选择排序
#includestdio.h
void main()//主函数
{
int a[10];
int i,j,w;
printf("请输入10个数字: \n");
for(i=0;i10;i++)
scanf("%d",a[i]);
for(i=0;i10;i++)
{
for(j=i+1;j10;j++)
if(a[i]a[j])//进行比较
//比较后进行交换
{
w=a[i];
a[i]=a[j];
a[j]=w;
}
C语言中从键盘上输入三个数,将之排序后按由大到小的顺序输出
具体操作方法如下:
#includestdio.h
int main(void)
{int a,b,c,t;
printf("请输入三个数");
scanf("%d%d%d",a,b,c);
if(ab)
{t=a;a=b;b=t;}
if(bc)
{t=b;b=c;c=t;}
if(ab)
{t=a;a=b,b=t;}
printf("从大到小:%d %d %d",a,b,c);
system("pause");
return 0;}
注意:中间的t=a;a=b;b=t,就是交换a和b的位置,总是把大的换到前面来。
扩展资料:
c语言任意输入5个数,并按从大到小顺序输出的方法如下:
#include stdio.h
#include stdlib.h
int main()
{int a[5];
int i,j,k;
for(i=0;i=4;i++)
{scanf("%d",a[i]);}
for(i=0;i=4;i++){
for(j=0;j=4;j++)
{if(a[i]a[j])
{k=a[i]; a[i]=a[j]; a[j]=k;}}}
printf("排序结果是:\n");
for(i=0;i=4;i++)
{ printf("%d\t",a[i]);
}return 0;
C语言 输入三个数 按由小到大排序 函数调用的方法
#includestdio.h
mian()
{
int f(int *pointer1,int *pointer2,int *pointer3); \\对要进行调用的函数进行声明
int change(int *po1,int *po2);
int a,b,c,*p1,*p2,*p3; \\定义整形三个变量和三个指针变量。
scanf("%d %d %d",a,b,c);
p1=a; p2=b; p3=c;
f(*p1,*p2,*p3); \\调用函数f()
printf("排序后的三个数为:%d%d%d\n",a,b,c);
}
int f(int *pointer1,int *pointer2,int *pointer3)
{
if(*pointer1*pointer2) change(*pointer1,*pointer2);
if(*pointer1*pointer3) change(*pointer1,*pointer3);
if(*pointer2*pointer3) change(*pointer2,*pointer3);
}
int change(int *po1,int *po2)
{
int t;
t=*po1;
*po1=*po2;
*po2=t;
}
c语言编程....输入10个数到一维数组中,按升序排序后输出。分别用3个函数 实现数据的输入,排序和输出。
// sort.c by 乐观次品
// 以下常用的排序算法都在这里了,希望能帮到你。
#include stdio.h
#define N 15
#define swap(A,B) {int temp; temp = A; A = B; B = temp;}
#define min(A,B) ((AB)?A:B)
/*int partition(int *a,int l,int r)
{
int v = a[l];
int left = l, right = r+1;
while(1)
{
while(a[++left]v leftr);
while(a[--right]v);
if(leftright) swap(a[left],a[right])
else break;
}
swap(a[l],a[right]);
return right;
}
void quicksort(int *a,int l,int r)
{
int mid;
if(l = r) return;
mid = partition(a,l,r);
quicksort(a,l,mid-1);
quicksort(a,mid+1,r);
}
void merge(int *a,int l,int m,int r)
{
int b[N];
int i =l, j=m+1, k =0;
while(i=m j=r)
{
if(a[i]a[j]) b[k++] = a[i++];
else b[k++] = a[j++];
}
while(i=m) b[k++] = a[i++];
while(j=r) b[k++] = a[j++];
for(k=0,i=l;i=r;i++,k++) a[i] = b[k];
}
void mergesort(int *a,int l,int r)
{
int step=1;
int i;
for(step=1;stepr;step = 2*step)
for(i=l;i=r;i=i+2*step)
merge(a,i,min(i+step-1,r),min(i+2*step-1,r));
}
void mergesort(int *a,int l,int r)
{
int mid = (l+r)/2;
if(l=r) return;
mergesort(a,l,mid);
mergesort(a,mid+1,r);
merge(a,l,mid,r);
}
void shellsort(int *a, int len)
{
int step;
int i,j;
int temp;
for(step = len/2; step=1; step /=2)
{
for(i=step;ilen;i++)
{
j = i;
temp = a[i];
while(j-step=0 a[j-step] temp)
{
a[j] = a[j-step];
j -= step;
}
a[j] = temp;
}
}
}
void insertsort(int *a, int len)
{
int i,j;
int temp;
for(i=1;ilen;i++)
{
j=i;
temp = a[i];
while(j0 a[j-1]temp)
{
a[j] = a[j-1];
j--;
}
a[j]=temp;
}
}
void selectsort(int *a, int l,int r)
{
int i,j,min;
for(i=l;ir;i++)
{
min=i;
for(j=i+1;j=r;j++)
{
if(a[j]a[min]) min=j;
}
swap(a[i],a[min]);
}
} */
void heapadjust(int *a,int k,int n)
{
int j;
while(2*k = n)
{
j = 2*k;
if(a[j]a[j+1] jn-1) j++;
if(a[k]=a[j]) break;
swap(a[k],a[j]);
k = j;
}
}
void heapsort(int *a,int l,int r)
{
int k,n=r-l+1;
for(k=n/2;k=l;k--)
heapadjust(a,k,n);
while(rl)
{
swap(a[l],a[r]);
r--;
heapadjust(a,l,r);
}
}
void main()
{
int a[N] = {65,70,80,65,50,90,44,65,65,33,22};
int i;
printf("\n before sort :\n");
for(i=0;iN;i++) printf(" %d",a[i]);
//quicksort(a,0,N-1);
//mergesort(a,0,N-1);
//shellsort(a,N);
//insertsort(a,N);
//selectsort(a,0,N-1);
heapsort(a,0,N-1);
printf("\n after sort :\n");
for(i=0;iN;i++) printf(" %d",a[i]);
}
文章标题:C语言中用三个函数排序 c语言中几种排序方法
分享路径:http://myzitong.com/article/dooshoc.html