python输入列表求列表元素和(eval的运用)_浙大PTA-Python题库 编程题第六章(6-1~6-8)题解...

其他各章题解链接如下

浙大PTA-Python题库 编程题第一章(1-1~1-3)题解

https://blog.csdn.net/zimuzi2019/article/details/107020657

浙大PTA-Python题库编程题 第二章(2.1~2.14)题解

https://blog.csdn.net/zimuzi2019/article/details/106984549

浙大PTA-Python题库 编程题第三章(3-1~3-22)题解

https://blog.csdn.net/zimuzi2019/article/details/107040596

浙大PTA-Python题库 编程题第四章(4-1~4-30)题解

https://blog.csdn.net/zimuzi2019/article/details/107040603

浙大PTA-Python题库 编程题第五章(5-1~5-11)题解

https://blog.csdn.net/zimuzi2019/article/details/107020929

浙大PTA-Python题库 编程题第六章(6-1~6-8)题解

https://blog.csdn.net/zimuzi2019/article/details/107020979

浙大PTA-Python题库 编程题第七章(7-1)题解

https://tuenity.blog.csdn.net/article/details/102723092

注:第七章只有一道题,因为正则表达式学校尚不要求我就还没看,所以这道题解的链接是另一个大佬的

浙大PTA-Python题库 函数题(6-1~6-6)题解

https://blog.csdn.net/zimuzi2019/article/details/107021024

题目列表

6-1 输入列表,求列表元素和(eval输入应用)

在一行中输入列表,输出列表元素的和。

输入格式:

一行中输入列表。

输出格式:

在一行中输出列表元素的和。

输入样例:

[3,8,-5]

输入样例:

6

题解

print(sum(eval(input())))

6-2 一帮一

“一帮一学习小组”是中小学中常见的学习组织方式,老师把学习成绩靠前的学生跟学习成绩靠后的学生排在一组。本题就请你编写程序帮助老师自动完成这个分配工作,即在得到全班学生的排名后,在当前尚未分组的学生中,将名次最靠前的学生与名次最靠后的异性学生分为一组。

输入格式:

输入第一行给出正偶数N(≤50),即全班学生的人数。此后N行,按照名次从高到低的顺序给出每个学生的性别(0代表女生,1代表男生)和姓名(不超过8个英文字母的非空字符串),其间以1个空格分隔。这里保证本班男女比例是1:1,并且没有并列名次。

输出格式:

每行输出一组两个学生的姓名,其间以1个空格分隔。名次高的学生在前,名次低的学生在后。小组的输出顺序按照前面学生的名次从高到低排列。

输入样例:

8

0 Amy

1 Tom

1 Bill

0 Cindy

0 Maya

1 John

1 Jack

0 Linda

输出样例:

Amy Jack

Tom Linda

Bill Maya

Cindy John

题解

N,boylist,girllist,peoplist=eval(input()),[],[],[]

for i in range(N):

temp=list(input().split())

peoplist.append(temp)

if eval(temp[0])==1:

boylist.append(temp[1])

else:

girllist.append(temp[1])

for i in peoplist[:N//2]:

if eval(i[0])==1:

print(i[1],girllist[-1])

girllist.pop(-1)

else:

print(i[1],boylist[-1])

boylist.pop(-1)

6-3 列表或元组的数字元素求和

求列表中数字和,列表中嵌套层次不限2层

输入格式:

在一行中输入列表或元组

输出格式:

在一行中输出数字的和

输入样例:

在这里给出一组输入。例如:

[11,2,[3,7],(68,-1),"123",9]

输出样例:

在这里给出相应的输出。例如:

99

题解

strin,flag,temp,sum,flag1=input(),0,'',0,0

for index,i in enumerate(strin):

if (i=="'" or i=='"') and flag1==1:

flag1=0

elif flag1==1:

continue

elif(i=="'" or i=='"') and flag1==0:

flag1=1

continue

elif i.isdigit() and flag==0:

if strin[index-1]=='-':

flag=1

temp=temp+'-'+i

else:

flag=1

temp+=i

elif i.isdigit() and flag==1:

temp+=i

elif i.isdigit()==False and flag==1:

flag=0

sum+=int(temp)

temp=''

print(sum)

6-4 列表数字元素加权和(1)

输入一个嵌套列表,嵌套层次不限,根据层次,求列表元素的加权和。第一层每个元素 的值为:元素值 * 1,第二层每个元素的值为:元素值 * 2,第三层每个元素的值为:元素值 * 3, …,以此类推!

输入格式:

在一行中输入列表

输出格式:

在一行中输出加权和

输入样例:

在这里给出一组输入。例如:

[1,2,[3,4,[5,6],7],8]

输出样例:

在这里给出相应的输出。例如:

72

题解

import copy

strin=input()

strcopy,sum,count,layer=copy.deepcopy(strin),0,0,0

strin=strin.replace('[', '')

strin=strin.replace(']', '')

numlist=strin.split(',')

for i in range(len(strcopy)):

if strcopy[i]=='[':

layer+=1

elif strcopy[i]==']':

layer-=1

elif strcopy[i]==',':

continue

elif strcopy[i+1]==','or strcopy[i+1]==']':

sum+=eval(numlist[count])*layer

count+=1

print(sum)

6-5 列表元素个数的加权和(1)

输入一个嵌套列表,嵌套层次不限,根据层次,求列表元素的加权个数和。第一层每个元素算一个元素,第二层每个元素算2个元素,第三层每个元素算3个元素,第四层每个元素算4个元素,…,以此类推!

输入格式:

在一行中输入一个列表。

输出格式:

在一行中输出加权元素个数值。

输入样例:

在这里给出一组输入。例如:

[1,2,[3,4,[5,6],7],8]

输出样例:

在这里给出相应的输出。例如:

15

题解

import copy

strin=input()

strcopy,sum,layer=copy.deepcopy(strin),0,0

strin=strin.replace('[', '')

strin=strin.replace(']', '')

for i in range(len(strcopy)):

if strcopy[i]=='[':

layer+=1

elif strcopy[i]==']':

layer-=1

elif strcopy[i]==',':

continue

elif strcopy[i+1]==','or strcopy[i+1]==']':

sum+=layer

print(sum)

6-6 求指定层的元素个数

输入一个嵌套列表,再输入层数,求该层的数字元素个数。

输入格式:

第一行输入列表 第二行输入层数

输出格式:

在一行中输出元素个数

输入样例:

在这里给出一组输入。例如:

[1,2,[3,4,[5,6],7],8]

3

输出样例:

在这里给出相应的输出。例如:

2

题解

strin=input()

layerin,layernow,elemsum=eval(input()),0,0

for i in range(len(strin)):

if strin[i]=='[':

layernow+=1

elif strin[i]==']':

layernow-=1

if (layerin==layernow) and (strin[i]!='[') and strin[i]!=']' and strin[i]!=',' and strin[i+1].isdigit()!=True:

elemsum+=1

print(elemsum)

6-7 找出总分最高的学生

定N个学生的基本信息,包括学号(由5个数字组成的字符串)、姓名(长度小于10的不包含空白字符的非空字符串)和3门课程的成绩([0,100]区间内的整数),要求输出总分最高学生的姓名、学号和总分。

输入格式:

输入在一行中给出正整数N(≤10)。随后N行,每行给出一位学生的信息,格式为“学号 姓名 成绩1 成绩2 成绩3”,中间以空格分隔。

输出格式:

在一行中输出总分最高学生的姓名、学号和总分,间隔一个空格。题目保证这样的学生是唯一的。

输入样例:

5

00001 huanglan 78 83 75

00002 wanghai 76 80 77

00003 shenqiang 87 83 76

10001 zhangfeng 92 88 78

21987 zhangmeng 80 82 75

输出样例:

zhangfeng 10001 258

题解

num=int(input())

stulist=[list(input().split()) for i in range(num)]

success=[sum([eval(stulist[i][j]) for j in [2,3,4]]) for i in range(num)]

index=success.index(max(success))

print(stulist[index][1],stulist[index][0],success[index])

6-8 *输出全排列(选作)

输入整数n(3<=n<=7),编写程序输出1,2,...,n整数的全排列,按字典序输出。

输入格式:

一行输入正整数n。

输出格式:

按字典序输出1到n的全排列。每种排列占一行,数字间无空格。

输入样例:

在这里给出一组输入。例如:

3

输出样例:

在这里给出相应的输出。例如:

123

132

213

231

312

321

题解

n=eval(input())

start,end=int(pow(10,n-1)),(n+1)*int(pow(10,n-1))

numlist=set([str(i) for i in range(1,n+1)])

for i in range(start,end):

i=str(i)

iset=set()

for j in i:

iset.add(j)

if numlist==iset:

print(int(i))

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 这是一条使用 Python 脚本进行目标检测评估的命令。该命令使用了一个名为 eval_rcnn.py 的 Python 脚本,并传入了三个参数: 1. --cfg_file:表示使用的配置文件,默认为 cfgs/default.yaml; 2. --eval_mode:表示评估模式,此处为 rcnn,表示使用 RCNN 模型进行评估; 3. --eval_all:表示评估全部数据集,即对所有图像进行评估。 这个命令的具体作用是评估 RCNN 模型在指定数据集上的目标检测性能,并输出评估结果。 ### 回答2: 这条命令是用于在Python中执行一个名为eval_rcnn.py的脚本。它使用了三个指定参数: 1. --cfg_file:指定要使用的配置文件,默认为cfgs/default.yaml。配置文件通常包含了一些模型的设置,如网络结构、训练参数、数据集路径等。 2. --eval_mode:指定评估模式为rcnn,其中"rcnn"通常表示使用R-CNN(Region Proposal Network-Convolutional Neural Network)算法进行目标检测。 3. --eval_all:表示对所有样本进行评估,而不仅仅是某个子集。这是一种在测试阶段进行全面评估的常见做法,以评估模型在整个数据集上的性能。 综上所述,该条命令的目的是在Python环境中运行一个名为eval_rcnn.py的脚本,使用指定的配置文件(cfgs/default.yaml)对R-CNN算法进行目标检测,并对整个数据集进行评估。 ### 回答3: 这个命令是用于在 Python 中运行 eval_rcnn.py 脚本,它的参数含义如下: --cfg_file cfgs/default.yaml:指定配置文件为 cfgs/default.yaml。配置文件是用来设置模型的超参数和其他相关参数的文件,这里使用的是 default.yaml 文件。 --eval_mode rcnn:设置评估模式为 rcnn。这表示模型会根据预训练的 RCNN 算法进行评估。 --eval_all:这个参数用来进行全面评估。它会评估模型在数据集中的所有样本上的性能,而不仅仅是某个特定的子集。通常在训练完成后,使用该参数来对模型进行全面评估,以得到一个更全面的性能指标。 总之,这个命令会使用指定的模型配置文件和评估模式,在所有的数据样本上对模型进行评估,并输出评估结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值