第三次测试题目

1.利用numpy从1-100生成一个n乘n矩阵,求对角线元素之和,n由控制台输入

from numpy import random
import numpy as np
size = int(input("请输入所求矩阵大小:"))
a = random.randint(1,100,size=(size,size))
print(a)
b = np.fliplr(a) #将a矩阵 在左右方向上翻转 flipud(a)是上下方向翻转
result=np.trace(a)+np.trace(b)#求两个矩阵的迹(主对角线的和)
print(result)

输出结果
在这里插入图片描述

2.根据文件String.txt 计算其行平均有效字符数

(1)有效行指包含至少一个字符的行,不计算空行
(2)每行的字符数为其有效字符数(不计回车)
(3)行平均字符数采用四舍五入方式取整数进位。

file = open("String.txt","r",encoding="utf-8")
a = 0
data=""
for line in file:
       if line.split():
           data =data+line
           a=a+1
line.replace('\n','').replace('\r','')
print("有效行为:{}".format(a))
print("行平均字符数为:{:.0f}".format(len(data)/a))

输出结果:
在这里插入图片描述

3.输入一个由n(n>1)个数字组成的列表ls,并根据该列表输出一个新列表lt,其中lt中第i个元素等于ls中除ls[i]之外所有元素的乘积。

注意:输入输出均为列表。
例如:输入[1,2,3,4],输出[24, 12, 8, 6]。

n = input("请以列表格式输入一个列表:\n")
ls = list(n[1:-1].split(",")) #将输入的字符串转化为字符串列表
ls = list(map(int,ls)) #将字符串列表转换为数字列表
lt = []
print(ls)
num = 1
for i in range(len(ls)):
    for j in range(len(ls)):
        num = num * ls[j]
    num = num / ls[i]
    lt.append(num)
    num = 1
print(lt)

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值