1.要求:中间最大,其右边依次比其左边大。2.实现方法1:是先对数组排序;然后,对有序数组排座位。
3.分别采用数组法、函数法、指针法、实参形参为数组名。
先对数组排序;然后按中间最大,其右边依次比其左边大复制到另一个数组中
你题目的解答代码如下:
#include<stdio.h>
#include<string.h>
void sort(int a[],int n)
{
int i,j,g1,g2;
int b[n];
for(i=0;i<n-1;i++)
for(j=0;j<n-i-1;j++)
if(a[j] < a[j+1])
{
int t = a[j];
a[j] = a[j+1];
a[j+1] = t;
}
g1 = (n-1)/2;
g2 = g1+1;
for(i=0;i<n;i++)
{
if (i%2==0)
{
b[g1--] = a[i];
}
else
{
b[g2++] = a[i];
}
}
for(i=0;i<n;i++)
a[i] = b[i];
}
void main()
{
int n,i;
scanf("%d", &n);
int a[n];
for( i=0; i<n; i++ )
scanf("%d", &a[i]);
sort(a,n);
for( i=0; i<n; i++ )
printf("%d ", a[i]);
}
您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!如有帮助,请点击我的回答下方的【采纳该答案】按钮帮忙采纳下,谢谢!