从键盘输入10个整数,用函数编程实现计算其最大值和最小值,并互换它们所在数组中的位置

以下是我自己写的,可以找出最大最小值,却无法交换它们在数组中的位置,一定要用到Swap函数,请大神指教QAQ!!

#include<stdio.h>
#define N 10
void FindMaxMin(int a[],int *max,int *min,int *maxPos,int *minPos);
void Swap(int *x,int *y);

int main()
{
int i,a[N],max,min,maxPos,minPos;
printf("Input a:");
for(i=0;i<10;i++)
{
scanf("%d",&a[i]);
}
FindMaxMin(a,&max,&min,&maxPos,&minPos);
printf("AfterSwap:\n");
printf("Max=%d,Min=%d,maxPos=%d,minPos=%d\n",max,min,maxPos,minPos);
for(i=0;i<10;i++)
{
printf("%d ",a[i]);
}
return 0;
}

void FindMaxMin(int a[],int* max,int* min,int* maxPos,int* minPos)
{
int i,temp1,temp2;
*max=a[0];
*min=a[0];
*maxPos=0;
*minPos=0;

for(i=1;i<10;i++)
{
if(a[i]>*max)
{
*max=a[i];
*maxPos=i;

}
else if(a[i]<*min)
{
*min=a[i];
*minPos=i;
}
}
Swap(&max,&min);
}

void Swap(int *x,int *y)
{
int temp;
temp=*x;
*x=*y;
*y=temp;
}

1.找出数组中的最大值和最小值索引位置,然后将其交换即可
#include <stdio.h>

// 交换最大、最小值位置
void SwapLimVal(int *src, int len)
{
int max , min, maxlen = 0, minlen = 0;
max = min = src[0]; // 初始化最大、最小值暂时为第一个
for (int i = 1; i < len; i++)
{
if (max < src[i]) // 元素如果比最大数的,则重置最大值,及其索引
{
max = src[i];
maxlen = i;
}
else if (min > src[i])// 元素如果比最小数的,则重置最小值,及其索引
{
min = src[i];
minlen = i;
}
}
if (maxlen == minlen) // 如果所有值一样,不用交换
return;
int tem = src[maxlen]; // 交换最大、最小值
src[maxlen] = src[minlen];
src[minlen] = tem;
}

int main()
{
int a[10];
printf("intput 10 number : "); // 输入10个整数
for (int i = 0; i < 10; i++)
scanf("%d", &a[i]);
SwapLimVal(a, 10);
for (int i = 0; i < 10; i++) // 输出交换结果
printf("%d ", a[i]);
return 0;
}
温馨提示:内容为网友见解,仅供参考
第1个回答  2016-05-31
void swap(int &a, int &b)  
{    
    int tmp = 0;  
    tmp = b;  
    b = a;  
    a = tmp;  
 }

swap这么写

追问

这是CB里运行的结果

追答

我自己在dev c++里完全正常啊

#include <iostream>

/* run this program using the console pauser or add your own getch, system("pause") or input loop */
void swap(int &a, int &b)  
{    
    int tmp = 0;  
    tmp = b;  
    b = a;  
    a = tmp;  
 }
int main(int argc, char** argv) {
int n,m;
   n=1;
   m=2;
swap(n,m);
printf("m值为:%d", m);
system("PAUSE");
return 0;
}

本回答被提问者采纳
相似回答