从键盘输入10个整数,用函数编程实现计算其最大值和最小值,并互换它们所在数组中的位置
以下是我自己写的,可以找出最大最小值,却无法交换它们在数组中的位置,一定要用到Swap函数,请大神指教QAQ!!#include<stdio.h>#defineN10vo...
以下是我自己写的,可以找出最大最小值,却无法交换它们在数组中的位置,一定要用到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;
} 展开
#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;
} 展开
2个回答
展开全部
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;
}
#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;
}
展开全部
void swap(int &a, int &b)
{
int tmp = 0;
tmp = b;
b = a;
a = tmp;
}
swap这么写
追答
我自己在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;
}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询