缘由n 个数存放在数组中,用指针指向数组首地址,在子函数中用指针做形参实现:将最小值与第一个数交换。在主函数中输出交换后的 n 个数_编程语言-CSDN问答
无序数组从头和尾向中间找最小值后指针返回0交换即可
n 个数存放在数组中,用指针指向数组首地址,在子函数中用指针做形参实现:将最小值与第一个数交换。在主函数中输出交换后的 n 个数。n个数为:3 5 7 4 8 2 9.
cpp
void 无序数组指针交换(int* a, int* l)
{//缘由https://ask.csdn.net/questions/8156571/54901375
int *x = a, b = 0;
xh:if (a < l)
{
if (*++a < *x)
x = a;
if (*--l < *x)
x = l;
++b;
goto xh;
}
a -= b;
b = *a, *a = *x, *x = b;
}
int a[]{3, 5, 7, 4, 8, 2, 9}, n = 7;
无序数组指针交换(a, a + n - 1);
缘由指针-输入十个数存入一位数组中,最大数与最后一个数交换,最小数与第一个交换_编程语言-CSDN问答
cpp
void 无序数组指针交换(int* a, int* l)
{//缘由https://ask.csdn.net/questions/8156571/54901375
int *x = a, b = 0, *d = l;
xh:if (a < l)
{
if (*++a < *x)x = a; if (*a > *d)d = a;
if (*--l < *x)x = l; if (*l > *d)d = l;
++b;
goto xh;
}
a -= b; l += b;
if (a != x)b = *a, *a = *x, *x = b;
if (l != d)b = *l, *l = *d, *d = b;
}