Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 501|回复: 0

[算法学习]经典算法:鸡尾酒排序

[复制链接]
  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2014-11-13 00:06:07 | 显示全部楼层 |阅读模式
    问题     有一数组,长度为n,把数组中的元素从小到大重新排列。  说明     鸡尾酒(cocktail)排序,又叫搅拌(shaker)排序。是改良的冒泡排序,冒泡排 序可见另一篇文章经典算法之冒泡排序思路     鸡尾酒排序的过程为:(1)先对数组从左到右进行冒泡排序(升序),则最大的元 素去到最右端;(2)再对数组从右到左进行冒泡排序(降序),则最小的元素去到最左 端。以此类推,依次改变冒泡的方向,并不断缩小未排序元素的范围。     例如对45 ,19, 77, 81, 13, 28, 18, 19, 77进行排序     从左到右:19,45,77,13,28,18,19,77,81     从右到左:13,19,45,77,18,28,19,77,81     从左到右:13,19,45,18,28,18,77,77,81     从右到左:13,18,19,45,18,28,77,77,81     从左到右:13,18,19,18,28,45,77,77,81     从右到左:13,18,18,19,28,45,77,77,81     这时不再发生交换,排序结束。  核心代码:
       
         
        static
         
        void
         sort(
        int
        [] array) {
             
        int
         top
        =
         array.length
        -
         
        1
        ;
             
        int
         bottom
        =
         
        0
        ;
             
        boolean
         flag
        =
         
        true
        ;
             
        int
         i, j;
             
        while
         (flag) {
                 flag
        =
         
        false
        ;
                
        //
        从小到大,升序
       

                   
        for
         (i
        =
         bottom; i
        <
         top; i
        ++
        ) {
                     
        if
         (array
        >
         array[i
        +
         
        1
        ]) {
                         swap(array, i, i
        +
         
        1
        );
                         flag
        =
         
        true
        ;
                     }
                 }
                 top
        --
        ;
                
                
        //
        从大到小,降序
       

                   
        for
         (j
        =
         top; j
        >
         bottom; j
        --
        ) {
                     
        if
         (array[j]
        <
         array[j
        -
         
        1
        ]) {
                         swap(array, j, j
        -
         
        1
        );
                         flag
        =
         
        true
        ;
                     }
                 }
                 bottom
        ++
        ;
             }
         }
        全部代码:  Code

          package com.icescut.classic.algorithm;

    public class CocktailSort {

         public static void main(String[] args) {
             int[] array = { 10, -3, 5, 34, -34, 5, 0, 9 }; // test data
             sort(array);
             for (int el : array) {
                 System.out.print(el + " ");
             }
         }
         
         static void sort(int[] array) {
             int top = array.length - 1;
             int bottom = 0;
             boolean flag = true;
             int i, j;
             while (flag) {
                 flag = false;
                 //从小到大,升序
                 for (i = bottom; i < top; i++) {
                     if (array > array[i + 1]) {
                         swap(array, i, i + 1);
                         flag = true;
                     }
                 }
                 top--;
                
                 //从大到小,降序
                 for (j = top; j > bottom; j--) {
                     if (array[j] < array[j - 1]) {
                         swap(array, j, j - 1);
                         flag = true;
                     }
                 }
                 bottom++;
             }
         }

         private static void swap(int[] array, int i, int j) {
             int tmp = array;
             array = array[j];
             array[j] = tmp;
         }

    }
       
       

       
         
         
          
          

            
          

            
          
         
       

      


    源码下载:http://file.javaxxz.com/2014/11/13/000606656.zip
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-2-25 07:49 , Processed in 0.332104 second(s), 34 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表