#include <stdio.h>
#include <stdint.h>
#include <stdbool.h>
void swap(uint8_t *a, uint8_t *b) {
uint8_t tmp = *a;
*a = *b;
*b = tmp;
}
void bubble_sort_desc(uint8_t *arr, uint8_t n) {
int i, j;
bool swapped;
for (i = 0; i < n; i++) {
swapped = false;
for (j = 0; j < n - 1 - i; j++) {
if (arr[j] < arr[j + 1]) {
swap(&arr[j], &arr[j + 1]);
swapped = true;
}
}
if (!swapped)
break;
}
}
int main() {
uint8_t n;
scanf("%hhu", &n);
uint8_t arr[100];
for (uint8_t i = 0; i < n; i++) {
scanf("%hhu", &arr[i]);
}
bubble_sort_desc(arr, n);
for (uint8_t i = 0; i < n; i++) {
printf("%hhu", arr[i]);
if(i < n-1){
printf(" ");
}
}
return 0;
}
Input
5 10 3 5 2 7
Expected Output
10 7 5 3 2