#include <stdio.h>
#define REORDER3(b1, b2, b3, a1, a2, a3 ) \
{ \
typeof(a1) _tmp[] = {a1, a2, a3}; \
b1 = _tmp[0]; b2 = _tmp[1]; b3 = _tmp[2]; \
} while ( 0 )
#define uintprint3(a) printf("%u %u %u\n", a[0], a[1], a[2])
void sort3( unsigned int a[3] )
{
if (a[0] > a[1])
if (a[1] > a[2])
{
REORDER3 (
a[0], a[1], a[2],
a[2], a[1], a[0]);
return;
}
else
if (a[0] > a[2])
{
REORDER3 (
a[0], a[1], a[2],
a[1], a[2], a[0]);
return;
}
else
{
REORDER3 (
a[0], a[1], a[2],
a[1], a[0], a[2]);
return;
}
else
if (a[1] <= a[2])
return; //NO REORDER
else
if (a[0] <= a[2])
{
REORDER3 (
a[0], a[1], a[2],
a[0], a[2], a[1] );
return;
}
else
{
REORDER3 (
a[0], a[1], a[2],
a[2], a[0], a[1] );
return;
}
}
int main(void)
{
unsigned int a[] = {0, 1, 2};
unsigned int b[] = {0, 2, 1};
unsigned int c[] = {1, 2, 0};
unsigned int d[] = {1, 0, 2};
unsigned int e[] = {2, 0, 1};
unsigned int f[] = {2, 1, 0};
sort3(a); sort3(b); sort3(c); sort3(d); sort3(e); sort3(f);
uintprint3(a);
uintprint3(b);
uintprint3(c);
uintprint3(d);
uintprint3(e);
uintprint3(f);
return 0;
}
I2luY2x1ZGUgPHN0ZGlvLmg+CgojZGVmaW5lIFJFT1JERVIzKGIxLCBiMiwgYjMsIGExLCBhMiwgYTMgKSAgIFwKeyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcCiAgdHlwZW9mKGExKSBfdG1wW10gPSB7YTEsIGEyLCBhM307ICAgICAgICAgXAogIGIxID0gX3RtcFswXTsgYjIgPSBfdG1wWzFdOyBiMyA9IF90bXBbMl07IFwKfSB3aGlsZSAoIDAgKQoKI2RlZmluZSB1aW50cHJpbnQzKGEpIHByaW50ZigiJXUgJXUgJXVcbiIsIGFbMF0sIGFbMV0sIGFbMl0pCgoKdm9pZCBzb3J0MyggdW5zaWduZWQgaW50IGFbM10gKQp7CgogIGlmIChhWzBdID4gYVsxXSkKICAgIGlmIChhWzFdID4gYVsyXSkKICAgICAgewogICAgICAgIFJFT1JERVIzICgKICAgICAgICAgICAgICAgICAgYVswXSwgYVsxXSwgYVsyXSwKICAgICAgICAgICAgICAgICAgYVsyXSwgYVsxXSwgYVswXSk7CiAgICAgICAgcmV0dXJuOwogICAgICB9CiAgICBlbHNlCiAgICAgIGlmIChhWzBdID4gYVsyXSkKICAgICAgICB7CiAgICAgICAgICBSRU9SREVSMyAoCiAgICAgICAgICAgICAgICAgICAgYVswXSwgYVsxXSwgYVsyXSwKICAgICAgICAgICAgICAgICAgICBhWzFdLCBhWzJdLCBhWzBdKTsKICAgICAgICAgIHJldHVybjsKICAgICAgICB9CiAgICAgIGVsc2UKICAgICAgICB7CiAgICAgICAgICBSRU9SREVSMyAoCiAgICAgICAgICAgICAgICAgICAgYVswXSwgYVsxXSwgYVsyXSwKICAgICAgICAgICAgICAgICAgICBhWzFdLCBhWzBdLCBhWzJdKTsKICAgICAgICAgIHJldHVybjsKICAgICAgICB9CiAgZWxzZQogICAgaWYgKGFbMV0gPD0gYVsyXSkKICAgICAgcmV0dXJuOyAvL05PIFJFT1JERVIKICAgIGVsc2UKICAgICAgaWYgKGFbMF0gPD0gYVsyXSkKICAgICAgICB7CiAgICAgICAgICBSRU9SREVSMyAoCiAgICAgICAgICAgICAgICAgICAgYVswXSwgYVsxXSwgYVsyXSwKICAgICAgICAgICAgICAgICAgICBhWzBdLCBhWzJdLCBhWzFdICk7CiAgICAgICAgICByZXR1cm47CiAgICAgICAgfQogICAgICBlbHNlCiAgICAgICAgewogICAgICAgICAgUkVPUkRFUjMgKAogICAgICAgICAgICAgICAgICAgIGFbMF0sIGFbMV0sIGFbMl0sCiAgICAgICAgICAgICAgICAgICAgYVsyXSwgYVswXSwgYVsxXSApOwogICAgICAgICAgcmV0dXJuOwogICAgICAgIH0KfQoKaW50IG1haW4odm9pZCkKewogIHVuc2lnbmVkIGludCBhW10gPSB7MCwgMSwgMn07CiAgdW5zaWduZWQgaW50IGJbXSA9IHswLCAyLCAxfTsKICB1bnNpZ25lZCBpbnQgY1tdID0gezEsIDIsIDB9OwogIHVuc2lnbmVkIGludCBkW10gPSB7MSwgMCwgMn07CiAgdW5zaWduZWQgaW50IGVbXSA9IHsyLCAwLCAxfTsKICB1bnNpZ25lZCBpbnQgZltdID0gezIsIDEsIDB9OwogIHNvcnQzKGEpOyBzb3J0MyhiKTsgc29ydDMoYyk7IHNvcnQzKGQpOyBzb3J0MyhlKTsgc29ydDMoZik7CgogIHVpbnRwcmludDMoYSk7CiAgdWludHByaW50MyhiKTsKICB1aW50cHJpbnQzKGMpOwogIHVpbnRwcmludDMoZCk7CiAgdWludHByaW50MyhlKTsKICB1aW50cHJpbnQzKGYpOwogIHJldHVybiAwOwp9