其他各章题解链接如下
浙大PTA-Python题库 编程题第一章(1-1~1-3)题解

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

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

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

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

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

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

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

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

题目列表

Python第6章习题 python第六章课后编程题_Python第6章习题

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))