C++实现双向起泡排序算法

 更新时间:2022年11月09日 15:41:31   作者:学得放不下  
这篇文章主要为大家详细介绍了如何利用C++实现双向起泡排序算法,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以尝试一下

起泡排序的基本思想

起泡排序易于冒泡排序算法合并,即向后推出最大数。将被排序的记录数组R[1..n]垂直排列,每个记录R[i]看作是重量为R[i]的气泡。根据轻气泡不能在重气泡之下的原则,从下往上扫描数组R:凡扫描到违反本原则的轻气泡,就使其向上“飘浮”。如此反复进行,直到最后任何两个气泡都是轻者在上,重者在下为止。一般地,第i遍处理时,不必检查第i个位置以上的元素,因为经过前面i-1遍的处理,它们已正确地排好序。即就是在一组待排序的数据中,两两比较数据的大小,发现两个记录的排序次序相反时就交换位置,直到没有反序的记录为止。也就是说它重复地走访过要排序的序列,一次比较两个项目,如果他们的顺序错误就把他们交换过来。走访序列的工作是重复地进行直到没有再需要做交换动作,该序列已经排序完成。一趟冒泡,至少可以把值最大的元素送到最后位置(或最上边);当然也可以倒过来做,把值小的元素向前移或向下移,一趟冒泡,至少可以把值最小的元素送到最前面的位置(或最下边)。

双向起泡排序实现如下

#include<iostream>
using namespace std;

// 交换两个数
void swap(int &i, int &j)
{
    int t = i;
    i = j;
    j = t;
}

// 打印数组
void show(int a[], int n)
{
    for(int i = 0; i < n; i++)
    {
        cout << a[i] << " ";
    }
    cout << endl;
}

// 双向起泡排序
void bubblesort(int a[], int n)
{
    int low = 0, high = n-1;
    bool flag = true;

    while(low < high && flag)
    {   
        flag = false;

        show(a, 10);
        int i = low;
        while(i < high)
        {
            if(a[i] > a[i + 1])
            {
                swap(a[i], a[i + 1]);
                flag = true;
            }
            i++;
        }
        high--;
        
        int j = high;
        while(j > low)
        {
            if(a[j] < a[j-1])
            {
                swap(a[j-1], a[j]);
                flag = true;
            }
            j--;
        }
        low++;
    }
}

int main(){
    int a[] = {10, 9, 8, 7, 6, 5, 4, 3, 2, 1};
    int n = 10;

    // 输出初始状态
    // show(a, n);

    // 双向冒泡排序
    bubblesort(a, n);

    // 排序后输出
    cout << "after sort" << endl;
    show(a, n);

}

代码中示例的输出为:

10 9 8 7 6 5 4 3 2 1 
1 9 8 7 6 5 4 3 2 10 
1 2 8 7 6 5 4 3 9 10
1 2 3 7 6 5 4 8 9 10
1 2 3 4 6 5 7 8 9 10
after sort
1 2 3 4 5 6 7 8 9 10

以上就是C++实现双向起泡排序算法的详细内容,更多关于C++双向起泡排序的资料请关注脚本之家其它相关文章!

相关文章

  • C++实现学生成绩管理系统

    C++实现学生成绩管理系统

    这篇文章主要为大家详细介绍了C++实现学生成绩管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-12-12
  • C++编程中私有和保护以及公有的类成员访问控制

    C++编程中私有和保护以及公有的类成员访问控制

    这篇文章主要介绍了C++编程中私有和保护以及公有的类成员访问控制,即private和protected以及public关键字的相关作用和用法,需要的朋友可以参考下
    2016-01-01
  • 深入学习C语言mmap和shm*的使用方法技巧

    深入学习C语言mmap和shm*的使用方法技巧

    本文将详细介绍mmap和shm的工作原理,包括它们在内存映射和共享内存方面的优势和适用场景,同时,文章还会分享一些使用mmap和shm的技巧和经验,以帮助读者优化并提高程序性能,使你能够在实际项目中更好地利用这些技术来加速数据共享和多线程应用
    2023-10-10
  • C++深度探索虚函数指针示例

    C++深度探索虚函数指针示例

    虚函数主要通过V-Table虚函数表来实现,该表主要包含一个类的虚函数的地址表,可解决继承、覆盖的问题,下面这篇文章主要给大家介绍了如何通过一篇文章带你掌握C++虚函数的来龙去脉,需要的朋友可以参考下
    2022-12-12
  • C++ 单链表的基本操作(详解)

    C++ 单链表的基本操作(详解)

    下面小编就为大家带来一篇C++ 单链表的基本操作(详解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-12-12
  • C语言获取Shell返回结果的实现方法

    C语言获取Shell返回结果的实现方法

    下面小编就为大家带来一篇C语言获取Shell返回结果的实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-07-07
  • c++如何将一个char转化为string

    c++如何将一个char转化为string

    这篇文章主要介绍了c++如何将一个char转化为string问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • C语言实现学籍管理系统

    C语言实现学籍管理系统

    这篇文章主要为大家详细介绍了C语言实现学籍管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • C++利用SQLite实现命令行工具

    C++利用SQLite实现命令行工具

    这篇文章主要为大家详细介绍了一个基于 C++、SQLite 和 Boost 库的简单交互式数据库操作 Shell,该 Shell 允许用户通过命令行输入执行各种数据库操作,感兴趣的可以了解下
    2023-11-11
  • 深入C/C++浮点数在内存中的存储方式详解

    深入C/C++浮点数在内存中的存储方式详解

    本篇文章是对C/C++浮点数在内存中的存储方式进行了详细的分析介绍,需要的朋友参考下
    2013-05-05

最新评论