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]的极差和方差,并打印原极差和保留三位有效数字的方差。

++运行效果展示:++

++++

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

相关推荐
shizhenshide1 分钟前
极速响应:平均破解速度<3秒的验证码服务,为抢购爬虫而生
算法
AD钙奶-lalala2 分钟前
leetcode核心母题总结
算法·leetcode·职场和发展
EZ_Python4 分钟前
告别WPS会员!用Python自制电子发票批量打印排版工具
python·自动化
写文章的大米6 分钟前
1 分钟读懂:Python 装饰器
python
2501_9216494912 分钟前
股指期货 API 入门指南:如何获取实时行情与构建交易系统
python·websocket·金融·区块链·restful
努力学算法的蒟蒻17 分钟前
day53(1.4)——leetcode面试经典150
算法·leetcode·面试
leiming620 分钟前
c++ transform算法
开发语言·c++·算法
裴云飞31 分钟前
Compose原理一之快照系统
算法·架构
橘颂TA32 分钟前
【剑斩OFFER】哈希表简介
数据结构·算法·散列表
小尧嵌入式33 分钟前
c++红黑树及B树B+树
开发语言·数据结构·c++·windows·b树·算法·排序算法