照相排序 1.要求:中间最大,其右边依次比其左边大。2.实现方法1:是先对数组排序;然后,对有序数组排座位。 3.分别采用数组法、函数法、指针法、实参形参为数组名。

1.要求:中间最大,其右边依次比其左边大。2.实现方法1:是先对数组排序;然后,对有序数组排座位。
3.分别采用数组法、函数法、指针法、实参形参为数组名。

先对数组排序;然后按中间最大,其右边依次比其左边大复制到另一个数组中

img

你题目的解答代码如下:

#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]);
}

如有帮助,请点击我的回答下方的【采纳该答案】按钮帮忙采纳下,谢谢!

img

您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632