【数据分析面试】8.计算标准差(python)

2024-04-03 11:44

本文主要是介绍【数据分析面试】8.计算标准差(python),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

题目:

编写一个名为 compute_deviation 的函数,该函数接受一个包含键和整数列表的字典列表,并返回一个字典,其中包含每个列表的标准差。

注意:请勿使用 NumPy 内置函数。

示例:

输入:

input = [{'key': 'list1','values': [4,5,2,3,4,5,2,3],},{'key': 'list2','values': [1,1,34,12,40,3,9,7],}
]

输出:

 output = {'list1': 1.12, 'list2': 14.19}

答案

解题思路

该函数 compute_deviation 接受一个字典列表作为输入,其中每个字典包含一个键和一个整数列表。它计算每个列表的标准差,而不使用 NumPy 内置函数,并返回一个包含每个列表标准差的字典。

  1. 定义了一个名为 compute_deviation 的函数,接受一个列表作为输入。
  2. 函数内部遍历输入列表中的每个字典。
  3. 对于每个字典,提取键和对应的整数列表。
  4. 使用给定的整数列表计算其标准差,将结果存储在一个新的字典中,以当前字典中的键作为键,标准差作为值。
  5. 最后返回这个包含标准差的字典。

答案代码

# 定义一个函数,计算每个列表的标准差
def compute_deviation(input):# 创建一个空字典,用于存储结果result = {}# 遍历输入列表中的每个字典for item in input:# 获取当前字典中的键key = item['key']# 获取当前字典中键为'values'的值values = item['values']# 计算长度n = len(values)# 计算的平均值mean = sum(values) / n# 计算方差variance = sum((x - mean) ** 2 for x in values) / n# 计算标准差std_deviation = variance ** 0.5   # 将结果存储在结果字典中result[key] = std_deviation# 返回计算得到的结果字典return resultprint(compute_deviation(input_data))

另一个版本的答案是导入’math’ 库,用 math.sqrt() 函数计算标准差:

  • std_deviation = math.sqrt(variance)

如果使用Numpy,直接用np.std()计算,不用另外计算平均值和方差。

import numpy as npdef compute_deviation(input):result = {}for item in input:key = item['key']values = item['values']std_deviation = np.std(values)result[key] = std_deviationreturn result

常见NumPy函数汇总

NumPy是Python中用于科学计算的重要库,提供了许多常用的计算函数。以下是一些常见的NumPy计算函数的简单总结:

  1. np.array(): 将输入数据(列表、元组、数组等)转换为NumPy数组。
  2. np.arange(): 创建一个等差数组。
  3. np.linspace(): 创建一个等间隔数组。
  4. np.zeros(): 创建一个元素全为0的数组。
  5. np.ones(): 创建一个元素全为1的数组。
  6. np.eye(): 创建一个单位矩阵(对角线元素为1,其余为0)。
  7. np.random.rand(): 生成指定形状的随机数数组(0到1之间均匀分布)。
  8. np.random.randn(): 生成指定形状的随机数数组(标准正态分布)。
  9. np.sum(): 对数组中的元素求和。
  10. np.mean(): 计算数组中元素的平均值。
  11. np.std(): 计算数组中元素的标准差。
  12. np.var(): 计算数组中元素的方差。
  13. np.min(): 找出数组中的最小值。
  14. np.max(): 找出数组中的最大值。
  15. np.argmax(): 找出数组中最大值的索引。
  16. np.argmin(): 找出数组中最小值的索引。
  17. np.transpose() 或数组.T: 返回数组的转置。
  18. np.dot(): 计算两个数组的点积(内积)。
  19. np.cross(): 计算两个数组的叉积。
  20. np.linalg.norm(): 计算数组的范数。

在这里插入图片描述

这篇关于【数据分析面试】8.计算标准差(python)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/872827

相关文章

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

Python中win32包的安装及常见用途介绍

《Python中win32包的安装及常见用途介绍》在Windows环境下,PythonWin32模块通常随Python安装包一起安装,:本文主要介绍Python中win32包的安装及常见用途的相关... 目录前言主要组件安装方法常见用途1. 操作Windows注册表2. 操作Windows服务3. 窗口操作

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

python常用的正则表达式及作用

《python常用的正则表达式及作用》正则表达式是处理字符串的强大工具,Python通过re模块提供正则表达式支持,本文给大家介绍python常用的正则表达式及作用详解,感兴趣的朋友跟随小编一起看看吧... 目录python常用正则表达式及作用基本匹配模式常用正则表达式示例常用量词边界匹配分组和捕获常用re

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

python删除xml中的w:ascii属性的步骤

《python删除xml中的w:ascii属性的步骤》使用xml.etree.ElementTree删除WordXML中w:ascii属性,需注册命名空间并定位rFonts元素,通过del操作删除属... 可以使用python的XML.etree.ElementTree模块通过以下步骤删除XML中的w:as

使用Python绘制3D堆叠条形图全解析

《使用Python绘制3D堆叠条形图全解析》在数据可视化的工具箱里,3D图表总能带来眼前一亮的效果,本文就来和大家聊聊如何使用Python实现绘制3D堆叠条形图,感兴趣的小伙伴可以了解下... 目录为什么选择 3D 堆叠条形图代码实现:从数据到 3D 世界的搭建核心代码逐行解析细节优化应用场景:3D 堆叠图

深度解析Python装饰器常见用法与进阶技巧

《深度解析Python装饰器常见用法与进阶技巧》Python装饰器(Decorator)是提升代码可读性与复用性的强大工具,本文将深入解析Python装饰器的原理,常见用法,进阶技巧与最佳实践,希望可... 目录装饰器的基本原理函数装饰器的常见用法带参数的装饰器类装饰器与方法装饰器装饰器的嵌套与组合进阶技巧

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到