文章目录
L1-024 后天~5
如果今天是星期三,后天就是星期五;如果今天是星期六,后天就是星期一。我们用数字1到7对应星期一到星期日。给定某一天,请你输出那天的“后天”是星期几。
- 输入格式:
输入第一行给出一个正整数D(1 ≤ D ≤ 7),代表星期里的某一天。
- 输出格式:
在一行中输出D天的后天是星期几。
输入样例:
3
输出样例:
5
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
题解:
day = int(input())
if day == 5: # 列出特殊的星期五,输出
print(7)
else:
print((day+2)%7)
L1-018 大笨钟~10
微博上有个自称“大笨钟V”的家伙,每天敲钟催促码农们爱惜身体早点睡觉。不过由于笨钟自己作息也不是很规律,所以敲钟并不定时。一般敲钟的点数是根据敲钟时间而定的,如果正好在某个整点敲,那么“当”数就等于那个整点数;如果过了整点,就敲下一个整点数。另外,虽然一天有24小时,钟却是只在后半天敲1~12下。例如在23:00敲钟,就是“当当当当当当当当当当当”,而到了23:01就会是“当当当当当当当当当当当当”。在午夜00:00到中午12:00期间(端点时间包括在内),笨钟是不敲的。
下面就请你写个程序,根据当前时间替大笨钟敲钟。
输入格式:
输入第一行按照hh:mm的格式给出当前时间。其中hh是小时,在00到23之间;mm是分钟,在00到59之间。
输出格式:
根据当前时间替大笨钟敲钟,即在一行中输出相应数量个Dang。如果不是敲钟期,则输出:
Only hh:mm. Too early to Dang.
其中hh:mm是输入的时间。
输入样例1:
19:05
输出样例1:
DangDangDangDangDangDangDangDang
输入样例2:
07:05
输出样例2:
Only 07:05. Too early to Dang.
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
题解:
a, b = map(int, input().split(':'))
# print(a, b)
if a >= 0 and a <= 12: # 12点以前的(包括12点)
# %02d可控制输入的为两位数(即不足两位的不足两位)
print("Only %02d:%02d. Too early to Dang." % (a, b))
elif a > 12 and a < 24 and b != 0:
print("Dang"*((a-12)+1))
elif a > 12 and a < 24 and b == 0:
print("Dang"*(a-12))
[^1]:注意给出的输出样例不可出现小细节错误,不然会导致格式错误
L1-025 正整数A+B~15
题的目标很简单,就是求两个正整数A和B的和,其中A和B都在区间[1,1000]。稍微有点麻烦的是,输入并不保证是两个正整数。
输入格式:
输入在一行给出A和B,其间以空格分开。问题是A和B不一定是满足要求的正整数,有时候可能是超出范围的数字、负数、带小数点的实数、甚至是一堆乱码。
注意:我们把输入中出现的第1个空格认为是A和B的分隔。题目保证至少存在一个空格,并且B不是一个空字符串。
输出格式:
如果输入的确是两个正整数,则按格式A + B = 和输出。如果某个输入不合要求,则在相应位置输出?,显然此时和也是?。
输入样例1:
123 456
输出样例1:
123 + 456 = 579
输入样例2:
22. 18
输出样例2:
? + 18 = ?
输入样例3:
-100 blabla bla...33
输出样例3:
? + ? = ?
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
题解:
a, b = input().split(' ', 1) # split(' ', 1)括号里面的不可或缺(否则会有两个非零返回)
flag = True # 起标记作用
# # isdigit保证都为数字且.次数在a所出现的次数为0,及控制a, b区间在[1,1000]
if a.isdigit() and a.count('.')==0 and int(a)>0 and int(a) <= 1000:
print(a+" + ", end='')
else:
print("? + ", end='')
flag = False
if b.isdigit() and b.count('.') == 0 and int(b)>0 and int(b) <= 1000:
print(b+" = ", end='')
else:
print("? = ", end='')
flag = False
if flag:
print(int(a)+int(b))
else:
print("?")
L1-011 A-B~20
本题要求你计算A−B。不过麻烦的是,A和B都是字符串 —— 即从字符串A中把字符串B所包含的字符全删掉,剩下的字符组成的就是字符串A−B。
输入格式:
输入在2行中先后给出字符串A和B。两字符串的长度都不超过10
4
,并且保证每个字符串都是由可见的ASCII码和空白字符组成,最后以换行符结束。
输出格式:
在一行中打印出A−B的结果字符串。
输入样例:
I love GPLT! It's a fun game!
aeiou
输出样例:
I lv GPLT! It's fn gm!
代码长度限制
16 KB
时间限制
150 ms
内存限制
64 MB
题解:
a, b = input(), input()
for i in b: # 遍历b
a = a.replace(i, '') # 将b在a里面重复的替换成空的
print(a)
[1]:相比大家觉得这个题不值20分,可她就是20分哇,哈哈-^-
当然,也可以写成:
a, b = input(), input()
x = '' # 存储空字符
for i in a:
if i not in b:
x += i
print(x)
一天一点python小基础:
阶乘:
def fact(n):
s = 1
for i in range(1, n+1):
s *= i
return s
if __name__ == '__main__': # 函数调用
print(fact(5))
每日一言:
岁月是一台精准的计算器,她分毫不差地记录着你的付出和努力,衡量着你的底子和实力,测算着你的分量和价值——努力付出,岁月终不会辜负你。
上一页:PTA-基础编程部分题集
持续更新中…