湖畔读书人


私信TA

用户名:2814787590

访问量:128125

签 名:

等  级
排  名 21
经  验 19782
参赛次数 0
文章发表 42
年  龄 0
在职情况 学生
学  校 武汉东湖学院
专  业

  自我简介:

解题思路和注意事项:


这个题思路很明确,就是写三个函数来实现功能

我下面将自己在做得过程中出现的一些错误写了下来,大家可以看一下,引以为鉴。

主要是因为值交换不当引起的错误,看注释


参考代码:

#include<stdio.h>

int max = 0,min = 0;

void shuru(int a[])
{
	int i;
	for(i=0; i<10; i++){
		scanf("%d",&a[i]);
	}
}

void paixu(int a[])
{
	int i,temp = 0,n,m;
	max = min = a[0];
	for(i=0; i<10; i++){
		if(a[i]<min){
			min = a[i];
			n = i;
		}
		if(max>a[i]){            //下面三行代码是可以删掉的,因为下面用for循环选出了
			max = a[i];    //最大值,这里没删是给大家看一下错误示范
			m = i;
		}
	}
	temp = a[0];
	a[0] = min;
	a[n] = temp;
	for(i=0; i<10; i++){       //第一次错误代码是没有这个循环,所以答案是有误
		if(a[i]>max){       //我分析了半天,发现在前面的交换中数组中的值
			max = a[i];   //发生了变动;
			m = i;           //如果不做这个循环继续交换值的话,就可能将之前做过
		}                          //改动的值又一次改动,结果就会出错
	}
	temp = a[9];
	a[9] = max;
	a[m] = temp;
}

void shuchu(int a[])
{
	int i;
	for(i=0; i<10; i++)
		printf("%d ",a[i]);
	printf("\n");
}

int main()
{
	int a[10];
	shuru(a);
	paixu(a);
	shuchu(a);
	return 0;
}


 

0.0分

0 人评分

  评论区

  • «
  • »