【蓝桥杯备赛】Day07:循环结构程序设计(上)

题目1:题目 1151: C语言训练-计算一个整数N的阶乘

计算一个整数N的阶乘

输入格式

一个整数N, (0<=N<=12)

输出格式

整数N的阶乘.

样例输入

5

样例输出

120

python代码

import math
n=int(input())
print(math.factorial(n))

知识点

  1. math.factorial(x):计算x的阶乘
  2. 充分使用标准库,事半功倍的效果

题目2:题目 2796: 求整数的和与均值

读入n(1 <= n <= 10000)个整数,求它们的和与均值

输入格式

输入第一行是一个整数n,表示有n个整数。
第2~n+1行每行包含1个整数或多个整数。每个整数的绝对值均不超过10000

输出格式

输出一行,先输出和,再输出平均值(保留到小数点后5位),两个数间用单个空格分隔

样例输入

4
344
222
343
222 3

样例输出

1134 283.50000

python代码

list1 = list(map(int,input().split()))
n=list1[0]
list1.pop(0)
while len(list1)<n:
    list1.extend(map(int,input().split()))
print('%d %.5f'%(sum(list1),sum(list1)/n))

知识点

  1. 若无 一行输入“多个整数”,本题非常容易
  2. 需要熟练利用列表的操作

len(list):列表中的元素个数
max(list):列表中最大的元素
min(list):列表中最小的元素
list.copy():生成一个list的副本
list.sort():对列表进行顺序排列
list.sort(reverse=True):对列表进行逆序排列
list.reverse():对列表进行逆序排列
list.sort(key=None,reverse=False):对列表按照key键值顺序排列
list.append():列表
末尾新增元素
list.clear():清空列表
list.pop(i):删除列表中
索引值i的元素,函数返回 那个删除值
list.extend(t):t可为另外一个列表或字符串值(可迭代类型iterable)
list.count(i):统计listi出现次数
list.insert(i,str):在list索引值为i处插入str
list.index(i):在list中找到 第一个值为i的索引值

  1. %d为占位符,因此%d%.5f将会输出紧凑的两个数字,不符合题目要求

题目3:题目 2799: 奥运奖牌计数

2008年北京奥运会,A国的运动员参与了n天的决赛项目(1≤n≤17)。现在要统计一下A国所获得的金、银、铜牌数目及总奖牌数。

输入格式

输入n+1行,第1行是A国参与决赛项目的天数n,其后n行,每一行是该国某一天获得的金、银、铜牌数目,以一个空格分开

输出格式

输出1行,包括4个整数,为A国所获得的金、银、铜牌总数及总奖牌数,以一个空格分开。

样例输入

3
1 0 3
3 1 0
0 3 0

样例输出

4 4 3 11

python代码

n=int(input())
jins=yins=tongs=0
for i in range(n):
    list1=list(map(int,input().split()))
    jins+=list1[0]
    yins+=list1[1]
    tongs+=list1[2]
print('%d %d %d %d'%(jins,yins,tongs,jins+yins+tongs))

知识点

  1. 利用循环实现多行输入

题目4:题目 2803: 整数的个数

给定k(1 < k < 100)个正整数,其中每个数都是大于等于1,小于等于10的数。写程序计算给定的k个正整数中,1,5和10出现的次数

输入格式

输入有两行:第一行包含一个正整数k,第二行包含k个正整数,每两个正整数用一个空格分开

输出格式

输出有三行,第一行为1出现的次数,,第二行为5出现的次数,第三行为10出现的次数

样例输入

5
1 5 8 10 5

样例输出

1
2
1

python代码

起初代码:
n=int(input())
list1=list(map(int,input().split()))
a=b=c=0
for i in range(n):
    if list1[i]==1:
        a+=1
    elif list1[i]==5:
        b+=1
    elif list1[i]==10:
        c+=1
print(a,b,c,sep='\n')
改进代码:
n=int(input())
list1=list(map(int,input().split()))
print(list1.count(1))
print(list1.count(5))
print(list1.count(10))

知识点

  1. list.count(i):统计listi出现次数

题目5:编写题解 2810: 鸡尾酒疗法

鸡尾酒疗法,原指“高效抗逆转录病毒治疗”(HAART),由美籍华裔科学家何大一于1996年提出,是通过三种或三种以上的抗病毒药物联合使用来治疗艾 滋病。该疗法的应用可以减少单一用药产生的抗药性,最大限度地抑制病毒的复制,使被破坏的机体免疫功能部分甚至全部恢复,从而延缓病程进展,延长患者生 命,提高生活质量。人们在鸡尾酒疗法的基础上又提出了很多种改进的疗法。为了验证这些治疗方法是否在疗效上比鸡尾酒疗法更好,可用通过临床对照实验的方式 进行。假设鸡尾酒疗法的有效率为x,新疗法的有效率为y,如果y-x大于5%,则效果更好,如果x-y大于5%,则效果更差,否则称为效果差不多。下面给 出n组临床对照实验,其中第一组采用鸡尾酒疗法,其他n-1组为各种不同的改进疗法。请写程序判定各种改进疗法效果如何。

输入格式

第一行为整数n( 1 < n <= 20);
其余n行每行两个整数,第一个整数是临床实验的总病例数(小于等于10000),第二个疗效有效的病例数。
这n行数据中,第一行为鸡尾酒疗法的数据,其余各行为各种改进疗法的数据。

输出格式

有n-1行输出,分别表示对应改进疗法的效果:
如果效果更好,输出better;如果效果更差,输出worse;否则输出same。

样例输入

5
125 99
112 89
145 99
99 97
123 98

样例输出

same
worse
better
same

python代码

n=int(input())#统计行数
jl,jx=map(int,input().split())#jl:鸡尾酒临床试验总病例数 jx:有效病例数
j=jx/jl#有效率
list1=[]#空列表,准备放其他疗法的有效率
for i in range(n-1):
    gl,gx=map(int,input().split())
    list1.append(gx/gl)
for i in range(n-1):
    if list1[i]-j>0.05:
        print('better')
    elif j-list1[i]>0.05:
        print('worse')
    else:
        print('same')

知识点

1.list.append():列表末尾补充元素

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值