鸡尾酒排序

鸡尾酒排序,第1张

鸡尾酒排序
#include 

int CocktaiSort(int *array, int len)
{
    if (array == NULL)
        return -1;
    int i = 0;
    int j = 0;
    int temp = 0;
    for (i = 0; i < len / 2; i++)
    {
        int isSorted = 1;
        
        for (j = i; j < len - i - 1; j++)
        {
            if (array[j] > array[j + 1])
            {
                temp = array[j];
                array[j] = array[j + 1];
                array[j + 1] = temp;
                isSorted = 0;
            }
        }
        if (isSorted)
        {
            break;
        }

        // 偶数轮,从由右到左进行比较和交换
        isSorted = 1;
        for (j = len - i - 1; j > i; j--)
        {
            if (array[j] < array[j - 1])
            {
                temp = array[j];
                array[j] = array[j - 1];
                array[j - 1] = temp;
                isSorted = 0;
            }
        }
        if (isSorted)
        {
            break;
        }
    }
    return 0;
}
int main()
{
    int i = 0;
    
    int array[8] = {2, 3, 4, 5, 6, 7, 8, 1};
    CocktaiSort(array, 8);
    for (i = 0; i < 8; i++)
    {
        printf("%d ", array[i]);
    }
    return 0;
}

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5611276.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-15
下一篇 2022-12-15

发表评论

登录后才能评论

评论列表(0条)

保存