去掉一个数组中的最大值和最小值,算出剩余数的平均值

废话不多说,直接上代码,涉及到的排序算法可查看另一篇博客三种常见的排序算法中的冒泡排序。

代码实现

#include <stdio.h>
int main()
{
	//定义一个无序数组,后续测试可自行更改数据或长度
	int pNum[10] = { 23, 88, 57, 34, 56, 57, 45, 46, 57, 59 };

	//(1)先对数组进行排序,这里使用一个简单的冒泡排序
	for (int nIndex = 0; nIndex < (sizeof(pNum) / sizeof(pNum[0])); ++nIndex)
	{
		for (int nIdx = 0; nIdx < (sizeof(pNum) / sizeof(pNum[0] - 1 - nIndex)); ++nIdx)
		{
			if (pNum[nIdx] > pNum[nIdx + 1])
			{
				int nNumber = pNum[nIdx];
				pNum[nIdx] = pNum[nIdx + 1];
				pNum[nIdx + 1] = nNumber;
			}
		}
	}

	//(2)遍历数组,去掉第一个和最后,求和
	//因为去掉第一个和最后一个,所以从下表为1开始遍历到数组长度 - 1结束
	int nCount = 0;
	for (int nIndex = 1; nIndex < (sizeof(pNum) / sizeof(pNum[0] - 1)); ++nIndex)
	{
		//求和
		nCount += pNum[nIndex];
	}

	//(3)计算平均值
	printf("该数组去掉最大值和最小值之后的平均值为:%d", nCount / (sizeof(pNum) / sizeof(pNum[0]) - 2));

    return 0;
}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值