TheAlgorithms-C/sorting/bogo_sort.c

45 lines
712 B
C
Raw Normal View History

#include <stdbool.h>
2016-08-06 02:04:35 +08:00
#include <stdio.h>
#include <stdlib.h>
bool check_sorted(int *a, int n)
{
while (--n >= 1)
{
if (a[n] < a[n - 1])
return false;
}
return true;
2016-08-06 02:04:35 +08:00
}
void shuffle(int *a, int n)
{
int i, t, r;
for (i = 0; i < n; i++)
{
t = a[i];
r = rand() % n;
a[i] = a[r];
a[r] = t;
}
2016-08-06 02:04:35 +08:00
}
void sort(int *a, int n)
{
while (!check_sorted(a, n)) shuffle(a, n);
2016-08-06 02:04:35 +08:00
}
int main()
{
int numbers[6];
int i;
printf("Enter 6 numbers unsorted \n\n");
for (i = 0; i < 6; i++)
{
scanf("%d", &numbers[i]);
}
sort(numbers, 6);
for (i = 0; i < 6; i++) printf("%d ", numbers[i]);
printf("\n");
2016-08-06 02:04:35 +08:00
}