python趣味编程:歌星大奖赛

题目:歌星大奖赛
内容:在歌星大奖赛中,有10个评委为参赛的选手打分,分数为1到100分。选
手最后得分为去掉一个最高分和一个最低分后,其余8个分数的平均值。
问题分析和算法设计:
问题算法比较简单,主要是用到两个知识点,一是判断最大值和最小值,二是
计算平均值。

代码如下:

复制代码
##@小五义 http://www.cnblogs.com/xiaowuyi
'''
题目:歌星大奖赛
内容:在歌星大奖赛中,有10个评委为参赛的选手打分,分数为1到100分。选
手最后得分为去掉一个最高分和一个最低分后,其余8个分数的平均值。
'''
def inputscore(num):
    i=True  #判断输入的成绩是否合法
    while i:
        try:
            print '评委%d:'%num
            score=float(raw_input('请输入成绩(0-100):'))  
            if score>100 or score<0:
                print '输入错误,请重新输入'
                i=True
            else:
                i=False
        except:
            print '输入错误,请重新输入'
            i=True
    return score

if __name__=='__main__':
    sumscore=0  #求和
    maxscore=0  #记录最大成绩
    minscore=100  #记录最小成绩
    for i in range(10):
        intscore=inputscore(i+1)
        sumscore+=intscore
        if intscore>maxscore:
            maxscore=intscore
        elif intscore<minscore:
            minscore=intscore
    
    averagescore=(sumscore-maxscore-minscore)/8.0  #计算平均分
    print '去掉一个最高分%f,去掉一个最低分%f,本选手的最后得分是%f'%(maxscore,minscore,averagescore)
    
        
        
复制代码

转载请注明:@小五义  http://www.cnblogs.com/xiaowuyi

posted @   小五义  阅读(6733)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
点击右上角即可分享
微信分享提示