C 练习实例67
题目:输入数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。
程序分析:谭浩强的书中答案有问题。
实例
#include<stdio.h>
#include<stdlib.h>
void fun(int *s,int n)
{
int i;
int max=s[0];
int a=0;
for(i=0;i<n;i++)
{
if(s[i]>max)
{
max=s[i];
a=i;
}
}
s[a]=s[0];
s[0]=max;
int j;
int min=s[n-1];
int b=n-1;
for(j=0;j<n;j++)
{
if(s[j]<min)
{
min=s[j];
b=j;
}
}
s[b]=s[n-1];
s[n-1]=min;
}
void printf_s(int *s,int n)
{
int i;
for(i=0;i<n;i++)
printf("%d ",s[i]);
printf("\n");
}
int main()
{
int s[20];
int i,n;
printf("设置数组长度(<20):");
scanf("%d",&n);
printf("输入 %d 个元素:\n",n);
for(i=0;i<n;i++)
scanf("%d",&s[i]);
fun(s,n);
printf_s(s,n);
return 0;
}
输出结果未:
设置数组长度(<20):5 输入 5 个元素: 12 123 4 65 21 123 12 21 65 4
banhuxun
ban***[email protected]
参考解法
输出结果
banhuxun
ban***[email protected]
或零或百
838***[email protected]
参考代码:
或零或百
838***[email protected]
HIT_CCC
117***[email protected]
参考方法:
HIT_CCC
117***[email protected]
CCC
227***[email protected]
参考:
CCC
227***[email protected]
difficult is simple
257***[email protected]
本题体现出了指针的优越性:指针并不会改变原有数组的值和排列顺序,却可以储存数组中最大值与最小值的位置。当知道最大值与最小值的位置时,就可以定位出最值元素在数组中的编号(例如本题定位最值的数值与位置是通过 a(max - a) 和 a(min - a) 实现的)。
difficult is simple
257***[email protected]