PTA 团体程序设计天梯赛-练习集--L1-003~005(Python3)

L1-003 个位数统计 (15分)

给定一个 k 位整数 N=d
​k−1
​​ 10
​k−1
​​ +⋯+d
​1
​​ 10
​1
​​ +d
​0
​​ (0≤d
​i
​​ ≤9, i=0,⋯,k−1, d
​k−1
​​ >0),请编写程序统计每种不同的个位数字出现的次数。例如:给定 N=100311,则有 2 个 0,3 个 1,和 1 个 3。

输入格式:
每个输入包含 1 个测试用例,即一个不超过 1000 位的正整数 N。

输出格式:
对 N 中每一种不同的个位数字,以 D:M 的格式在一行中输出该位数字 D 及其在 N 中出现的次数 M。要求按 D 的升序输出。

输入样例:
100311
输出样例:
0:2
1:3
3:1

解答

data = input()

ans = {}  #创建字典
for i in range(0,len(data)):
    if data[i] in ans:    #当前值是否在答案中
        ans[data[i]] += 1    #数量加1
    else:    #不在,则创建新数值
        ans[data[i]] = 1
for i in sorted(ans):    #首先进行升序排列,并且按格式输出(不能放在一个print中输出,否则会格式错误)
    print(int(i),end='')
    print(":",end='')
    print(int(ans[i]))

L1-004 计算摄氏温度 (5分)

给定一个华氏温度F,本题要求编写程序,计算对应的摄氏温度C。计算公式:C=5×(F−32)/9。题目保证输入与输出均在整型范围内。

输入格式:
输入在一行中给出一个华氏温度。

输出格式:
在一行中按照格式“Celsius = C”输出对应的摄氏温度C的整数值。

输入样例:
150
输出样例:
Celsius = 65

解答

F = input()
C=5.0*(int(F)-32)/9  #注意先转化成float,最后输出int
print("Celsius =",int(C))

L1-005 考试座位号 (15分)

每个 PAT 考生在参加考试时都会被分配两个座位号,一个是试机座位,一个是考试座位。正常情况下,考生在入场时先得到试机座位号码,入座进入试机状态后,系统会显示该考生的考试座位号码,考试时考生需要换到考试座位就座。但有些考生迟到了,试机已经结束,他们只能拿着领到的试机座位号码求助于你,从后台查出他们的考试座位号码。

输入格式:
输入第一行给出一个正整数 N(≤1000),随后 N 行,每行给出一个考生的信息:准考证号 试机座位号 考试座位号。其中准考证号由 16 位数字组成,座位从 1 到 N 编号。输入保证每个人的准考证号都不同,并且任何时候都不会把两个人分配到同一个座位上。

考生信息之后,给出一个正整数 M(≤N),随后一行中给出 M 个待查询的试机座位号码,以空格分隔。

输出格式:
对应每个需要查询的试机座位号码,在一行中输出对应考生的准考证号和考试座位号码,中间用 1 个空格分隔。

输入样例:
4
3310120150912233 2 4
3310120150912119 4 1
3310120150912126 1 3
3310120150912002 3 2
2
3 4
输出样例:
3310120150912002 2
3310120150912119 1

解答

f = int(input())

infor = []
for i in range(0,f):
    infor.append([])
    infor[i] = input().split(' ')
find_num = int(input())
find_index = input().split(' ')

for x in range(0,find_num):
    for i in range(0,f):
        if infor[i][1] == find_index[x]:
            print(infor[i][0],infor[i][2])

你可能感兴趣的:(算法联系)