C语言.任意n个整数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换.如何实现 n个整数
来源:学生作业帮助网 编辑:六六作业网 时间:2024/10/04 06:09:12
C语言.任意n个整数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换.如何实现 n个整数
C语言.任意n个整数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换.
如何实现 n个整数
C语言.任意n个整数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换.如何实现 n个整数
/*
*/
#include <stdio.h>
#define MAXSIZE 100
#define MAX(a, b) (a) >= (b) ? 1 : 0
//判断a是否大于b
#define MIN(a, b) (a) <= (b) ? 1 : 0
//判断a是否小于b
int main(void)
{
int i, n, dat[MAXSIZE];
int x = 0, y = 0;
int max = 0, min = 0X0FFFFFFF;
printf("\n请输入n( n < 100 ):");
scanf("%d", &n);
printf("\n请输入%d个数据:\n", n);
for (i = 0; i < n; i++)
{
scanf("%d", dat + i); //输入
if ( MAX(dat[i], max) )
{
max = dat[i]; //刷新最大值
x = i; //保存最大数在第几位
}
else if ( MIN(dat[i], min) )
{
min = dat[i];//刷新最小值
y = i; //保存最小数在第几位
}
}
if ( (x == (n - 1)) && (y == 0) ){
//如果 最大数在最末位且最小为在最前为
}
else if ( y == (n - 1) )
{
//如果 最小数在最末尾
y = x;
dat[n - 1] = dat[n - 1] ^ dat[x];
dat[x] = dat[n - 1] ^ dat[x];
dat[n - 1] = dat[n - 1] ^ dat[x]; //交换
dat[0] = dat[0] ^ dat[y];
dat[y] = dat[0] ^ dat[y];
dat[0] = dat[0] ^ dat[y]; //交换
}
else
{
dat[n - 1] = dat[n - 1] ^ dat[x];
dat[x] = dat[n - 1] ^ dat[x];
dat[n - 1] = dat[n - 1] ^ dat[x]; //交换
dat[0] = dat[0] ^ dat[y];
dat[y] = dat[0] ^ dat[y];
dat[0] = dat[0] ^ dat[y]; //交换
}
printf("\n处理后的结果:");
for (i = 0; i < n; i++){
printf(" %d", dat[i]);
}//输出
return 0;
}