ACM 编程模式 控制台输入输出
目录
- 题目1 对输入的字符串进行排序后输出
- 题目2 计算a+b
- 题目3 读取矩阵
- 题目4 求水仙花数
- 总结
题目1 对输入的字符串进行排序后输出
输入描述:
多个测试用例,每个测试用例一行。
每行通过,隔开,有n个字符,n<100
输出描述
对于每组用例输出一行排序后的字符串,用’,'隔开,无结尾空格。
示例1
输入
a,c,bb
f,dddd
nowcoder
输出
a,bb,c
dddd,f
nowcoder
代码如下
while True: # 在控制台,一行输入完成,按回车键立即print结果
try:
input_str = input()
lst = input_str.split(',')
lst.sort()
print(','.join(lst))
except:
break
题目2 计算a+b
输入描述:
输入第一行包括一个数据组数 t (1 <= t <= 100)
接下来每行包括两个正整数 a, b (1 <= a, b <= 1000)
输出描述
输出a+b的结果。
示例1
输入
2
1 5
10 20
输出
6
30
代码如下
n = int(input())
for i in range(n):
a,b = map(int,input().strip().split())
print(a + b)
或者
n = int(input())
while n > 0:
a,b = map(int,input().split(' '))
# 等同于 a,b = map(int,input().strip().split())
print(a + b)
n -= 1
题目3 读取矩阵
输入描述:
输入一个矩阵,每行以空格分隔。
示例1
输入
3 2 3
1 6 5
7 8 9
代码如下
arr = []
while 1: # 在控制台,连按两次回车键代表输入结束,会print结果
s = input()
if s !="":
arr.append(list(map(int, s.split())))
else:
break
print(arr) # 使用自测数据按钮调试时用,正式提交时要删掉。
输出
[[3, 2, 3], [1, 6, 5], [7, 8, 9]]
题目4 求水仙花数
题目描述
春天是鲜花的季节,水仙花就是其中最迷人的代表,数学上有个水仙花数,他是这样定义的: “水仙花数”是指一个三位数,它的各位数字的立方和等于其本身,比如:153=1^3+ 5^3+ 3^3 现在要求输出所有在m和n范围内的水仙花数。
输入描述:
输入数据有多组,每组占一行,包括两个整数m和n(100<=m<=n<=999)。
输出描述
对于每个测试实例,要求输出所有在给定范围内的水仙花数,就是说,输出的水仙花数必须大于等于m,并且小于等于n,如果有多个,则要求从小到大排列在一行内输出,之间用一个空格隔开; 如果给定的范围内不存在水仙花数,则输出no; 每个测试实例的输出占一行。
样例输入
100 120
300 380
样例输出
no
370 371
代码如下
while True: # 或者 while 1:
m, n = map(int, input().split(" "))
num = m
arr = []
while num <= n:
ge = num%10
shi = (num//10)%10
bai = num//100
flag = pow(ge, 3) + pow(shi, 3) + pow(bai, 3)
if flag == num:
arr.append(num)
num += 1
if not arr:
print('no')
else:
for i in arr:
print(i, ' ')
链接: OJ在线编程常见输入输出练习场
总结