【团体程序设计天梯赛-部分练习集】

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-基础编程部分题集

持续更新中…

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值