// C program for implementation of selection sort
#include <stdio.h>
void swap(int* xp, int* yp)
{
int temp = *xp;
*xp = *yp;
*yp = temp;
}
void selectionSort(int arr[], int n)
{
int i, j, min_idx;
// One by one move boundary of unsorted subarray
for (i = 0; i < n - 1; i++) {
// Find the minimum element in unsorted array
min_idx = i;
for (j = i + 1; j < n; j++)
if (arr[j] < arr[min_idx])
min_idx = j;
// Swap the found minimum element with the first
// element
swap(&arr[min_idx], &arr[i]);
}
}
/* Function to print an array */
void printArray(int arr[], int size)
{
int i;
for (i = 0; i < size; i++)
}
// Driver program to test above functions
int main()
{
int arr[] = { 64, 25, 12, 22, 11 };
int n = sizeof(arr) / sizeof(arr[0]);
selectionSort(arr, n);
printArray(arr, n);
return 0;
}
Ly8gQyBwcm9ncmFtIGZvciBpbXBsZW1lbnRhdGlvbiBvZiBzZWxlY3Rpb24gc29ydCAKI2luY2x1ZGUgPHN0ZGlvLmg+IAoKdm9pZCBzd2FwKGludCogeHAsIGludCogeXApIAp7IAoJaW50IHRlbXAgPSAqeHA7IAoJKnhwID0gKnlwOyAKCSp5cCA9IHRlbXA7IAp9IAoKdm9pZCBzZWxlY3Rpb25Tb3J0KGludCBhcnJbXSwgaW50IG4pIAp7IAoJaW50IGksIGosIG1pbl9pZHg7IAoKCS8vIE9uZSBieSBvbmUgbW92ZSBib3VuZGFyeSBvZiB1bnNvcnRlZCBzdWJhcnJheSAKCWZvciAoaSA9IDA7IGkgPCBuIC0gMTsgaSsrKSB7IAoJCS8vIEZpbmQgdGhlIG1pbmltdW0gZWxlbWVudCBpbiB1bnNvcnRlZCBhcnJheSAKCQltaW5faWR4ID0gaTsgCgkJZm9yIChqID0gaSArIDE7IGogPCBuOyBqKyspIAoJCQlpZiAoYXJyW2pdIDwgYXJyW21pbl9pZHhdKSAKCQkJCW1pbl9pZHggPSBqOyAKCgkJLy8gU3dhcCB0aGUgZm91bmQgbWluaW11bSBlbGVtZW50IHdpdGggdGhlIGZpcnN0IAoJCS8vIGVsZW1lbnQgCgkJc3dhcCgmYXJyW21pbl9pZHhdLCAmYXJyW2ldKTsgCgl9IAp9IAoKLyogRnVuY3Rpb24gdG8gcHJpbnQgYW4gYXJyYXkgKi8Kdm9pZCBwcmludEFycmF5KGludCBhcnJbXSwgaW50IHNpemUpIAp7IAoJaW50IGk7IAoJZm9yIChpID0gMDsgaSA8IHNpemU7IGkrKykgCgkJcHJpbnRmKCIlZCAiLCBhcnJbaV0pOyAKCXByaW50ZigiXG4iKTsgCn0gCgovLyBEcml2ZXIgcHJvZ3JhbSB0byB0ZXN0IGFib3ZlIGZ1bmN0aW9ucyAKaW50IG1haW4oKSAKeyAKCWludCBhcnJbXSA9IHsgNjQsIDI1LCAxMiwgMjIsIDExIH07IAoJaW50IG4gPSBzaXplb2YoYXJyKSAvIHNpemVvZihhcnJbMF0pOyAKCXNlbGVjdGlvblNvcnQoYXJyLCBuKTsgCglwcmludGYoIlNvcnRlZCBhcnJheTogXG4iKTsgCglwcmludEFycmF5KGFyciwgbik7IAoJcmV0dXJuIDA7IAp9Cg==