【华为OD机试真题】树状结构查询- python

题目

通常使用多行的节点,父节点表示一棵树,比如
西安 陕西
陕西 中国
江西 中国
中国 亚洲
泰国 亚洲
输入一个节点之后,请打印出来树中他的所有下层节点

输入描述
第一行输入行数,下面是多行数据,每行以空格区分节点和父节点,接着是查询节点
输出描述
输出查询节点的所有下层节点。以字典序排序

示例1
输入
5
b a
c a
d c
e c
f d
c
输出
d
e
f

代码

def tree_select(N):
    ## 因所有节点不一定可以连接成一条线,所以不能把所有元素加入列表中
    tree={}
    #将输入的各节点存入字典中
    for _ in range(N):
        son,father=input('请输入该行字符:').split()
        tree.setdefault(father,list()) #构造字典的键作为列表结构,并添加对应值 其实集合比列表好,可以避免因输入重复值导致结果重复。
        tree[father].append(son)
    # 获取目标字符串
    target=input('目标字符串:')
    # 取到目标字符串后需要获取目标字符串后面的字符 :
    # 两种情况:1.作为叶子节点 即没有这个节点的下一个节点
    target_list=[]
    if tree.get(target) is None:
        return ''
    # 2 作为父节点,存在下层节点,这个相当于递归查找,确定目标列表,查询目标列表的长度,直到全部没有就结束
    #2.1 把当前主节点的元素放入目标列表中
    queue=tree[target] #存放过程中的元素
    #循环遍历当前节点
    while len(queue)>0:
        #拿到第一个元素,并放入目标表
        node=queue.pop(0)
        target_list.append(node)

    # 判断该节点下是否还有节点,若有则将该节点的元素加入过程列表进行下次遍历,直到列表为久结束
        if tree.get(node) is not None:
            queue.extend(tree[node])
    #拿到所有节点后进行排序 输出结果
    target_list.sort()
    for str in target_list:
        print(str)
    return
if __name__=='__main__':
   #字符串
    N = int(input('行数:'))
    # 安康 陕西
   # 西安 陕西
   # 陕西 中国
   # 河北 中国
   # 中国 亚洲
   
   # b a
   # c a
   # d c
   # e c
   # f d
    tree_select(N)

总结:

1.为字典设置默认key值的格式,如设置列表,集合。可以使用setdefault(key,默认值)
2.获取值得结果问题。本人最初想法是将每个值的结果都存储起来,即做成类似 {a:[b,c,d,e],b:[c.d.e]} 这种格式,但后面想想其实没必要。源数据已经存好了,我直接拿想查的结果再去查目标数据,会减少很多不必要的计算。而且代码也会没那么复杂。
所以 ,从中可以总结一点:如果源数据已经存下来了,需要获得的是其中的某个元素计算后的结果,就可以先拿到这个目标元素,然后再去计算结果,可以节省效率。
3.针对递归查询树状结构的下层元素的方式:通过while循环判断该列表内是否有元素,有则把该元素的下层元素又加入到该列表中。同时,删除当前查询元素。即需要有删有加的操作。再确定循环结束条件:列表为空即结束循环
4.特别说明:字段的key使用set集合会比列表有更大的容错性。

该题问题点

本题使用的是字典序,其实并不太合适。最好应该是按照层级展示结果会更好。即对查询到的值按照添加顺序展示。否则如果对地名按照这种方式操作,会不太好查询各地名的归属层级关系。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
华为OD要求使用Python实现分班功能,下面我将简要说明实现的思路。 首先我们需要读取输入的学生信息,包括姓名和成绩。可以使用Python的输入函数`input()`来实现,要求输入的学生信息按照一定格式排列,例如每行一个学生信息,姓名和成绩之间使用空格分隔。 我们可以定义一个空的字典来存储学生信息,姓名作为key,成绩作为value。我们可以使用Python的字典数据类型来实现,`student_dict = {}`。 然后,我们可以根据成绩对学生进行排序,可以使用Python的内置函数`sorted()`对字典的value进行排序,注意我们需要通过`student_dict.items()`将字典转换为可排序的列表。 接着我们需要根据排序后的学生列表来分班,根据目要求,每班的人数是相同的,假设为n。有两种常见的分班方式: 1. 按照学生的顺序,依次将学生分到不同的班级,当分到第n个学生时,再将学生分到下一个班级。可以使用取余运算符`%`来实现这个过程。 2. 先将学生按照成绩分组,成绩相同的学生放在一起,然后再将每组学生按照上述方式分到不同的班级。 最后,我们需要输出分班结果,可以使用Python的格式化输出语句将学生信息打印出来,例如`print("班级1: " + str(class1))`。 以上是我对华为OD的大致思路,具体的代码实现需要考虑一些细节问,并根据实际的需求进行调整。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值