1.函数实现

0)打印数组

/// <summary>
/// 打印数组
/// </summary>
/// <param name="arr">数组</param>
/// <param name="numberPerLine">每行打印元素数量</param>
/// <param name="digitAfterDot">小数点后保留位数</param>
private static void PrintArray(double[] arr, int numberPerLine = 7, int digitAfterDot = 2)
{
//设定小数点后保留位数(函数ToString()的参数)
string format = "#0.";
while (true)
{
if (digitAfterDot <= 0) break;
format += '0';
digitAfterDot--;
} //打印数组
for (int i = 0; i < (arr.Length - 1) / numberPerLine + 1; i++)
{
for (int j = 0; j < numberPerLine; j++)
{
int index = i * numberPerLine + j;
if (index < arr.Length)
{
Console.Write(arr[index].ToString(format) + "\t");
}
}
Console.WriteLine();
}
}

1)算术平均数:(x1+x2+...+xn)/n

/// <summary>
/// 计算算数平均数:(x1+x2+...+xn)/n
/// </summary>
/// <param name="arr">数组</param>
/// <returns>算术平均数</returns>
private static double ArithmeticMean(double[] arr)
{
double result = 0;
foreach (double num in arr)
{
result += num;
}
return result / arr.Length;
}

2)几何平均数:(x1*x2*...*xn)^(1/n)

/// <summary>
/// 几何平均数:(x1*x2*...*xn)^(1/n)
/// </summary>
/// <param name="arr">数组</param>
/// <returns>几何平均数</returns>
private static double GeometricMean(double[] arr)
{
double result = 1;
foreach (double num in arr)
{
result *= Math.Pow(num, 1.0 / arr.Length);
}
return result;
}

3)调和平均数:n/((1/x1)+(1/x2)+...+(1/xn))

/// <summary>
/// 调和平均数:n/((1/x1)+(1/x2)+...+(1/xn))
/// </summary>
/// <param name="arr">数组</param>
/// <returns>调和平均数</returns>
private static double HarmonicMean(double[] arr)
{
double temp = 0;
foreach (double num in arr)
{
temp += (1.0 / num);
}
return arr.Length / temp;
}

4)平方平均数:((x1*x1+x2*x2+...+xn*xn)/n)^(1/2)

/// <summary>
/// 平方平均数:((x1*x1+x2*x2+...+xn*xn)/n)^(1/2)
/// </summary>
/// <param name="arr">数组</param>
/// <returns>平方平均数</returns>
private static double RootMeanSquare(double[] arr)
{
double temp = 0;
foreach (double num in arr)
{
temp += (num * num);
}
return Math.Sqrt(temp / arr.Length);
}

5)中位数

/// <summary>
/// 计算中位数
/// </summary>
/// <param name="arr">数组</param>
/// <returns></returns>
private static double Median(double[] arr)
{
//为了不修改arr值,对数组的计算和修改在tempArr数组中进行
double[] tempArr = new double[arr.Length];
arr.CopyTo(tempArr, 0); //对数组进行排序
double temp;
for (int i = 0; i < tempArr.Length; i++)
{
for (int j = i; j < tempArr.Length; j++)
{
if (tempArr[i] > tempArr[j])
{
temp = tempArr[i];
tempArr[i] = tempArr[j];
tempArr[j] = temp;
}
}
} //针对数组元素的奇偶分类讨论
if (tempArr.Length % 2 != 0)
{
return tempArr[arr.Length / 2 + 1];
}
else
{
return (tempArr[tempArr.Length / 2] +
tempArr[tempArr.Length / 2 + 1]) / 2.0;
}
}

2.Main函数调用

static void Main(string[] args)
{
//一个数组
double[] arr = new double[]
{
3, 2, 7, 4, 8, 8, 5,
5, 6, 5, 1, 8, 4, 9
}; //打印数组
PrintArray(arr); //调和平均数≤几何平均数≤算术平均数≤平方平均数
Console.WriteLine("算术平均数:" + ArithmeticMean(arr).ToString("#0.000"));
Console.WriteLine("几何平均数:" + GeometricMean(arr).ToString("#0.000"));
Console.WriteLine("调和平均数:" + HarmonicMean(arr).ToString("#0.000"));
Console.WriteLine("平方平均数:" + RootMeanSquare(arr).ToString("#0.000"));
Console.WriteLine("中位数:" + Median(arr).ToString("#0.000")); Console.ReadLine();
}

3.运行示例

C#计算数组的算术平均数、几何平均数、调和平均数、平方平均数和中位数的更多相关文章

  1. 你必须知道的指针基础-4.sizeof计算数组长度与strcpy的安全性问题

    一.使用sizeof计算数组长度 1.1 sizeof的基本使用 如果在作用域内,变量以数组形式声明,则可以使用sizeof求数组大小,下面一段代码展示了如何使用sizeof: ,,,,,}; int ...

  2. JAVA 数组实例-求学生平均成绩,与计算数组的长度

    实例: 知识点:数组名.length是计算数组的长度 import java.util.*; //求学生平均分成绩 public class Test{ public static void main ...

  3. 李洪强iOS开发之计算数组的最大最小值

    // //  ViewController.m //  A21 - 李洪强 - 输出参数 // //  Created by vic fan on 16/7/3. //  Copyright © 20 ...

  4. PHP:第四章——PHP数组array_intersect计算数组交集

    <pre> <?php //array_intersect计算数组交集 header("Content-Type:text/html;charset=utf-8" ...

  5. PHP:第四章——PHP数组array_diff计算数组差集

    <pre> <?php header("Content-Type:text/html;charset=utf-8"); /*知识点一:array_diff — 计 ...

  6. PHP array_diff 计算数组的差集

    array_diff (PHP 4 >= 4.0.1, PHP 5) array_diff — 计算数组的差集 说明 array array_diff ( array $array1 , arr ...

  7. php计算数组相同值出现次数的代码(array_count_values)

    php计算数组相同值出现次数,可以使用php自带函数array_count_values : 说明 array array_count_values ( array $input )array_cou ...

  8. 计算数组arr中所有元素的和

    <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...

  9. js计算数组中每个元素出现的次数

    计算数组中每个元素出现的次数 var names = ['Alice', 'Bob', 'Tiff', 'Bruce', 'Alice']; var countedNames = names.redu ...

随机推荐

  1. Docker部署Python项目

    简介 软件开发最大的麻烦事之一就是环境配置,操作系统设置,各种库和组件的安装.只有它们都正确,软件才能运行.如果从一种操作系统里面运行另一种操作系统,通常我们采取的策略就是引入虚拟机,比如在 Wind ...

  2. Day12-微信小程序实战-交友小程序-优化“附近的人”页面与serach组件的布局和样式以及搜索历史记录和本地缓存*内附代码)

    回顾/:我们已经实现了显示附近的人的功能了,可以多个人看到附近的人页面了 但是还是要进行优化有几个问题:1.我们用户选择了其他的自定义头像之后,在首页可以看到头像的变化,但是在附近的人中头像会变成报错 ...

  3. 彻底搞懂Redis主从复制原理及实战

    欢迎关注公众号:「码农富哥」,致力于分享后端技术 (高并发架构,分布式集群系统,消息队列中间件,网络,微服务,Linux, TCP/IP, HTTP, MySQL, Redis), Python 等 ...

  4. Riccati方程迭代法求解

    根据上述迭代法求解P,P为Riccati方程的解,然而用LQR需要计算K,再将K算出. (迭代过程中 ,我们可以将此算法和dlqr函数求解的参数进行对比,当误差小于我们设置的允许误差我们就可以把此算法 ...

  5. "该公众号暂时无法提供服务,请稍后再试"的问题

    倒腾了好久,对微信公众号也不是很熟悉.不知道怎么看问题,php学的也不久. 1.定位问题. 网上找了很久,最后找到两种定位问题的方式. a.https://blog.csdn.net/qq_28506 ...

  6. 深度学习论文翻译解析(八):Rich feature hierarchies for accurate object detection and semantic segmentation

    论文标题:Rich feature hierarchies for accurate object detection and semantic segmentation 标题翻译:丰富的特征层次结构 ...

  7. HotSpot的类模型(2)

    在前一篇文章 HotSpot的二分模型中已经讲过,HotSpot采用了OOP-Klass模型描述Java的类和对象.Klass模型采用Klass类及相关子类来表示具体的Java类,可以理解这些类为Ja ...

  8. css3动画添加间隔

    因项目需要,需要在元素上实现动画效果,并且需要有动画间隔.坑爹的是animation-delay只有在第一次动画开始的时候才起效. 在网上找了很多方法,最终的方法基本都是改动画规则,比如 @keyfr ...

  9. [POJ1852] Ants(思维题)

    题干 An army of ants walk on a horizontal pole of length l cm, each with a constant speed of 1 cm/s. W ...

  10. request.headers.get头部获取内容的缺失

    1.说明 今天遇到了一个小坑,在做权限控制的时候,用头部传递了参数取名为table_privilege_id, 在本地测试的时候是可以接到这个参数的,但是通过ngxin转发之后,奇怪了,怎么也拿不到这 ...