Maison  >  Article  >  développement back-end  >  Comment implémenter le tri des bulles du plus grand au plus petit en langage C

Comment implémenter le tri des bulles du plus grand au plus petit en langage C

coldplay.xixi
coldplay.xixioriginal
2020-06-08 17:38:319791parcourir

Comment implémenter le tri des bulles du plus grand au plus petit en langage C

Comment implémenter le tri des bulles du plus grand au plus petit en langage C ?

Méthode de tri des bulles en langage C :

Sélectionnez d'abord le premier nombre comme étant le plus grand, puis comparez les nombres par paires pour obtenir la différence entre les deux. La valeur maximale entre eux est comparée séquentiellement. L'implémentation spécifique du code est la suivante :

#include <iostream>
#include <time.h>
using namespace std;
void srandData(int *, int );//产生随机数的函数
void bubbleSort(int *, int );//冒泡排序具体实现函数
void swap(int *, int *);//两个数字实现交换的函数
void display(int *, int );//在屏幕输出结果函数
int main()
{
const int N = 10;//定义常数
int arr[N];//定义数组
srandData(arr, N);
bubbleSort(arr, N);
display(arr, N);
return 0;
}
void srandData(int *a, int n)
{
srand(time(NULL));
for(int i = 0; i < n; i++)
{
a[i] = rand() % 50;//取50以下的数字
cout << a[i] << " ";
}
cout << endl;
}
void swap(int *b, int *c)
{
int temp = *c;
*c = *b;
*b = temp;
}
void bubbleSort(int *a, int n)
{
for(int i = 0; i < n; i++)
{
for(int j = 0; j < n - i - 1; j++)
{
if(a[j] < a[j + 1])
{
swap(&a[j], &a[j + 1]);//两者交换
}
}
}
}
void display(int *d, int n)
{
for(int i = 0; i < n; i++)
{
cout << d[i] << " ";
}
cout << endl;
}

Tutoriel recommandé : "Tutoriel vidéo C"

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn