【排序算法】冒泡排序法 & C++实现 | [实例过程分析]

简介: 冒泡排序法 & C++实现

●冒泡排序法


1.简要介绍

冒泡排序算法代码段:

for (int i = 0; i < len-1; i++)
  {
        int temp;
  for(int j=len-1;j>i;j--)
  { 
    if (a[j] > a[i])
    {
    temp = a[j];
    a[j ] = a[i];
    a[i] = temp;
    }
  }
  }

2.图形化演示

下面以代码程序排序中后五个数为例(从大到小排序),进行一个大致的图形排序理解。


       进行第一行中的排序,①不交换②交换③不交换④交换;


       进行第二行中的排序,①不换②不换③不换;


       进行第三行中的排序,①不交换②不交换;


       进行第四行中的排序,①不交换;


       第五行排序完成。

124c61d0a8aa70bbd5397ab37213c3b3_5b3ec71e97304b53bdb9561aac5a0dcd.png


3.代码如下

#include<iostream>
using namespace std;
#define size 10
class bubblesort {
public:
  void bubblesort_1(int a[],int len);
  void shownumber();
  int arr[size];
};
void bubblesort::bubblesort_1(int a[],int len)
{
  int temp;
  for (int i = 0; i < len-1; i++)
  {
  for(int j=len-1;j>i;j--)
  { 
    if (a[j ] > a[i])
    {
    temp = a[j ];
    a[j ] = a[i];
    a[i] = temp;
    }
  }
  //测试代码
  cout << i + 1 << ":" << " ";
  for (int k = 0; k < len; k++)
  {
    cout << a[k] << " ";
  }
  cout << endl;
  }
}
void bubblesort::shownumber()
{
  for (int i = 0; i < size; i++)
  {
  cout << this->arr[i] << " ";
  }
}
void text()
{
  bubblesort bs;
  for (int i = 0; i < size; i++)
  {
  cin >> bs.arr[i];
  }
  bs.bubblesort_1(bs.arr, size);
  bs.shownumber();
}
int main()
{
  text();
}

4.结果如下

4cff96706111e91f39f848d2c848c004_1915a151b15b4f29b75c4886617b4f51.png



目录
相关文章
|
1月前
|
Ubuntu Linux Shell
C++ 之 perf+火焰图分析与调试
【11月更文挑战第6天】在遇到一些内存异常的时候,经常这部分的代码是很难去进行分析的,最近了解到Perf这个神器,这里也展开介绍一下如何使用Perf以及如何去画火焰图。
|
2月前
|
存储 算法 搜索推荐
对二叉堆的简单分析,c和c++的简单实现
这篇文章提供了对二叉堆数据结构的简单分析,并展示了如何在C和C++中实现最小堆,包括初始化、插入元素、删除最小元素和打印堆的函数,以及一个示例程序来演示这些操作。
41 19
|
2月前
|
Ubuntu Linux Shell
C++ 之 perf+火焰图分析与调试
【10月更文挑战第8天】在遇到一些内存异常的时候,经常这部分的代码是很难去进行分析的,最近了解到Perf这个神器,这里也展开介绍一下如何使用Perf以及如何去画火焰图。
|
2月前
|
存储 算法 C++
高精度算法(加、减、乘、除,使用c++实现)
高精度算法(加、减、乘、除,使用c++实现)
649 0
高精度算法(加、减、乘、除,使用c++实现)
|
2月前
|
存储 算法 决策智能
【算法】博弈论(C/C++)
【算法】博弈论(C/C++)
|
2月前
|
存储 算法 C++
【算法】哈希映射(C/C++)
【算法】哈希映射(C/C++)
|
2月前
|
机器学习/深度学习 人工智能 算法
【算法】最长公共子序列(C/C++)
【算法】最长公共子序列(C/C++)
|
2月前
|
人工智能 算法 BI
一篇带你速通差分算法(C/C++)
一篇带你速通差分算法(C/C++)
|
23天前
|
存储 编译器 C语言
【c++丨STL】string类的使用
本文介绍了C++中`string`类的基本概念及其主要接口。`string`类在C++标准库中扮演着重要角色,它提供了比C语言中字符串处理函数更丰富、安全和便捷的功能。文章详细讲解了`string`类的构造函数、赋值运算符、容量管理接口、元素访问及遍历方法、字符串修改操作、字符串运算接口、常量成员和非成员函数等内容。通过实例演示了如何使用这些接口进行字符串的创建、修改、查找和比较等操作,帮助读者更好地理解和掌握`string`类的应用。
37 2
|
29天前
|
存储 编译器 C++
【c++】类和对象(下)(取地址运算符重载、深究构造函数、类型转换、static修饰成员、友元、内部类、匿名对象)
本文介绍了C++中类和对象的高级特性,包括取地址运算符重载、构造函数的初始化列表、类型转换、static修饰成员、友元、内部类及匿名对象等内容。文章详细解释了每个概念的使用方法和注意事项,帮助读者深入了解C++面向对象编程的核心机制。
82 5