python-随机序列(赛氪OJ)

[题目描述]

小理的作业太多了,怎么也做不完。

小理的数学作业由 T 张试卷组成,每张试卷上有 n 个数 a1..n​ ,小理需要算出这些数的极差和方差。极差是一个整数,方差是一个浮点数,要求保留到小数点后 3 位。虽然题目很简单,但计算量对于小理来说实在太大啦!你能帮一帮她吗?
输入格式:

输入的第一行有一个数 T ,表示试卷的数量;接下来的每 2 行,第一行有一个数 n ,表示当前试卷上数字的个数;第二行有 n 个数字ai​ ,表示这张试卷上的每一个数。
输出格式:

对每张试卷,输出一行两个数,分别表示这些数字的极差和方差,中间用空格分开。其中极差是整数,方差是保留到小数点后 3 位的浮点数。
样例输入

2

5

5 4 3 2 1

7

333 494 655 991 101 591 941
样例输出

4 2.000

890 86075.959
数据范围:

对于 100% 的数据,保证 1≤T≤100 ,1≤n≤103 ,1≤ai​≤5000。
提示说明:

一个数列的极差是指数列中最大的数减去最小的数,方差是指算出数列中每个数与数列平均值之差的平方后,对其求和,再除以数列元素个数得到的结果。

来源/分类(难度系数:二星数组 循环结构 模拟

++完整代码展示:++

number=int(input())

list_1=[]

for i in range(number):

n=int(input())

ai=list(map(int,input().split()))

list_1.append(ai)

a=0

while a<len(list_1):

b=int(max(list_1[a])-min(list_1[a]))

average=sum(list_1[a])/len(list_1[a])

sum_2=0

for j in range(0,len(list_1[a])):

sum_2+=(list_1[a][j]-average)**2

c="{:.3f}".format(sum_2/len(list_1[a]))

print(b,c)

a+=1

代码解释:

"number=int(input()) ",让用户输入试卷的张数number。

"list_1=[]
for i in range(number):
n=int(input())
ai=list(map(int,input().split()))
list_1.append(ai)
",建立一个空列表list_1,循环number次:让用户输入该张试卷上的字数,接着让用户输入每个代表字的数字,并将其储存在列表ai中,将ai添加进list_1中。

"a=0
while a<len(list_1):
b=int(max(list_1[a])-min(list_1[a]))
average=sum(list_1[a])/len(list_1[a])
sum_2=0
for j in range(0,len(list_1[a])):
sum_2+=(list_1[a][j]-average)**2
c="{:.3f}".format(sum_2/len(list_1[a]))
print(b,c)
a+=1
",令循环密码子为a,初始值为0,接着遍历历list_1中元素,按照极差和方差的定义分别求出list_1[a]的极差和方差,并打印原极差和保留三位有效数字的方差。

++运行效果展示:++

++++

(声明:以上内容均为原创)

相关推荐
菜鸟555552 小时前
图论:Floyd算法
算法·图论
呼啦啦啦啦啦啦啦啦7 小时前
常见的排序算法
java·算法·排序算法
喂完待续8 小时前
【Tech Arch】Spark为何成为大数据引擎之王
大数据·hadoop·python·数据分析·spark·apache·mapreduce
胡萝卜3.08 小时前
数据结构初阶:排序算法(一)插入排序、选择排序
数据结构·笔记·学习·算法·排序算法·学习方法
地平线开发者8 小时前
LLM 中 token 简介与 bert 实操解读
算法·自动驾驶
scx201310048 小时前
20250814 最小生成树和重构树总结
c++·算法·最小生成树·重构树
阿巴~阿巴~8 小时前
冒泡排序算法
c语言·开发语言·算法·排序算法
散1129 小时前
01数据结构-交换排序
数据结构·算法
王者鳜錸9 小时前
PYTHON让繁琐的工作自动化-猜数字游戏
python·游戏·自动化
yzx9910139 小时前
Yolov模型的演变
人工智能·算法·yolo