计算机二级Python题目13

目录

[1. 基本题](#1. 基本题)

[1.1 基本题1](#1.1 基本题1)

[1.2 基本题2](#1.2 基本题2)

[1.3 基本题3](#1.3 基本题3)

[2. turtle画图](#2. turtle画图)

[3. 大题](#3. 大题)

[3.1 大题1](#3.1 大题1)

[3.2 大题2](#3.2 大题2)


1. 基本题

1.1 基本题1

python 复制代码
ls=eval(input())
s=""
for item in ls:
    if type(item)==type("香山"):
        s+= item
print(s)

1.2 基本题2

python 复制代码
import random
random.seed(25)
n=random.randint(1,100)
for m in range(1,7):
    x=eval(input("请输入猜测数字:"))
    if x==n:
        print("恭喜你,猜对了!")
        break
    elif x>n:
        print("大了,再试试")
    else:
        print("小了,再试试")
    if m==6:
        print("谢谢!请休息后再猜")

1.3 基本题3

python 复制代码
def func(n):
    s=0
    if n%2==1:
        for i in range(1,n+1,2):
            s+=1/i
    else:
        for i in range(2,n+1,2):
            s+=1/i
    return s
number=int(input())
print("{:.2f}".format(func(number)))

注意:s=0; 和{:.2f}不要少了冒号

2. turtle画图

python 复制代码
from turtle import *
color=['red','green','blue']
rs=[10,30,60]
for i in range(3):
    penup()
    goto(0,-rs[i])
    pendown()
    pencolor(color[i])
    circle(rs[i])
done()

turtle.circle()中的参数是圆的半径,逆时针画圆

3. 大题

3.1 大题1

python 复制代码
import jieba
s=input("请输入一段中文文本,句子之间以逗号或句号分隔:")
slist=jieba.lcut(s)
m=0
for i in slist:
    if i in",。":
        continue
    else:
        m+=1
        print(i,end="/")
print("\n中文词语数是:{}\n".format(m))
poetry=''
for i in s:
    if i in ',。':
        print('{:^20}'.format(poetry))
        poetry=''
        continue
    poetry+=i

注意第二问的编程思路,以及continue的用法

3.2 大题2

第一问:

python 复制代码
f_data=open('data.txt','r',encoding="utf-8")
f_studs=open('studs.txt','w',encoding="utf-8")
ls=f_data.readlines()
for item in ls:
    a=item.strip().split(':')[0]+':'+item.split(',')[-1]
    f_studs.write(a)
f_data.close()
f_studs.close()

f_studs.write()每行写完自带换行符

第二问:

python 复制代码
f_data=open('data.txt','r',encoding="utf-8")
ls=f_data.readlines()
lst=[]
for item in ls:
    name=item.split(':')[0]
    score=item.split(',')[-1]
    lst.append([name,score])
lst.sort(key=lambda x:eval(x[1]),reverse=True)
print(lst[0][0]+':'+lst[0][1])
f_data.close()

利用lst.append()向列表中增加元素;注意排序的程序写法

第三问:

自己写的:

python 复制代码
f_data=open('data.txt','r',encoding="utf-8")
ls=f_data.readlines()
d={}
p={}
for item in ls:
    classname=item.split(':')[-1].split(',')[0]
    score=item.split(',')[-1]
    d[classname]=d.get(classname,0)+int(score)#班级总分
    p[classname]=p.get(classname,0)+1#班级人数
for i in d:
    print("{}:{:.2f}".format(i,d[i]/p[i]))
f_data.close()

参考答案:

python 复制代码
f_data=open('data.txt','r',encoding="utf-8")
students=f_data.readlines()
d={}
for student in students:
    student=student.strip().split(':')
    Class,score=student[1].split(',')
    d[Class]=d.get(Class,[])+[eval(score)]#班级总分
for key in d:
    avg_score=sum(d[key])/len(d[key]) #每个key对应一个分数列表
    print("{}:{:.2f}".format(key,avg_score))
f_data.close()

key对应的是一个列表

相关推荐
Vince丶20 分钟前
UE DirectExcel使用笔记
笔记·ue5
Trouville0133 分钟前
Pycharm软件初始化设置,字体和shell路径如何设置到最舒服
ide·python·pycharm
AA陈超41 分钟前
Lyra学习004:GameFeatureData分析
c++·笔记·学习·ue5·虚幻引擎
阿恩.77042 分钟前
2026年1月最新计算机、人工智能、经济管理国际会议:选对会议 = 论文成功率翻倍
人工智能·经验分享·笔记·计算机网络·金融·区块链
高-老师1 小时前
WRF模式与Python融合技术在多领域中的应用及精美绘图
人工智能·python·wrf模式
小白学大数据1 小时前
基于Splash的搜狗图片动态页面渲染爬取实战指南
开发语言·爬虫·python
零日失眠者1 小时前
【文件管理系列】003:重复文件查找工具
后端·python
FreeCode1 小时前
一文了解LangGraph智能体设计开发过程:Thinking in LangGraph
python·langchain·agent
('-')1 小时前
《从根上理解MySQL是怎样运行的》第二十章笔记
数据库·笔记·mysql
西柚小萌新1 小时前
【深入浅出PyTorch】--9.使用ONNX进行部署并推理
人工智能·pytorch·python