题目1:题目 1151: C语言训练-计算一个整数N的阶乘
计算一个整数N的阶乘
输入格式
一个整数N, (0<=N<=12)
输出格式
整数N的阶乘.
样例输入
5
样例输出
120
python代码
import math
n=int(input())
print(math.factorial(n))
知识点
math.factorial(x)
:计算x的阶乘- 充分使用标准库,事半功倍的效果
题目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))
知识点
- 若无 一行输入“多个整数”,本题非常容易
- 需要熟练利用列表的操作
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):统计list
中i
出现次数
list.insert(i,str):在list
索引值为i
处插入str
list.index(i):在list
中找到 第一个值为i
的索引值
%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))
知识点
- 利用循环实现多行输入
题目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))
知识点
list.count(i)
:统计list
中i
出现次数
题目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()
:列表末尾补充元素