Py小郑 2022-03-01 21:28 采纳率: 96.6%
浏览 34
已结题

Python有关字典和列表

两段代码
功能都是收集数据
就是第一行输出n,下面n-1行每行输出u,v,d,分别代表结点u,d,ud之间距离d
我用了两种方法

n=int(input())
point=[[] for i in range(n+1)]#n+1个顶点(有多余)point[i]=代表[i号点连接的顶点]
distance=[[float('inf')]*(n+1) for i in range(n+1)]#distance[i][j]i到j的距离
for i in range(n-1):
    tmp=list(map(int,input().split()))
    point[tmp[0]].append(tmp[1])
    point[tmp[1]].append(tmp[0])
    distance[tmp[0]][tmp[1]]=distance[tmp[1]][tmp[0]]=tmp[2]

上面这个是第一种,用两个列表存数据,一个列表存连接关系,一个列表存距离
但是这种方法在做题的时候出现内存超限了,,为啥?
我改变了数据结构,尝试使用字典,下面这段代码就满分通过了,为啥?

n=int(input())
point=dict((i,{})for i in range(n+1))#point=[0:{},1:{}....]  point[i][j]代表i到j的距离,同时能表示两者有连接
res=[0 for i in range(n+1)]
for i in range(n-1):
    tmp=list(map(int,input().split()))
    point[tmp[0]][tmp[1]]=tmp[2]
    point[tmp[1]][tmp[0]]=tmp[2]

第一种方法不就多了一个容器么,怎么差别会这么大

  • 写回答

1条回答 默认 最新

  • 陈年椰子 2022-03-02 11:02
    关注

    应该是这么回事:
    对于答题系统,判断比较严格,多一个列表,用的内存就不一样了。 循环次数多了, 判断也是超时。
    只能搞成最优,多余的东西一个都不留。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 3月10日
  • 已采纳回答 3月2日
  • 创建了问题 3月1日

悬赏问题

  • ¥20 软件测试决策法疑问求解答
  • ¥15 win11 23H2删除推荐的项目,支持注册表等
  • ¥15 matlab 用yalmip搭建模型,cplex求解,线性化处理的方法
  • ¥15 qt6.6.3 基于百度云的语音识别 不会改
  • ¥15 关于#目标检测#的问题:大概就是类似后台自动检测某下架商品的库存,在他监测到该商品上架并且可以购买的瞬间点击立即购买下单
  • ¥15 神经网络怎么把隐含层变量融合到损失函数中?
  • ¥15 lingo18勾选global solver求解使用的算法
  • ¥15 全部备份安卓app数据包括密码,可以复制到另一手机上运行
  • ¥20 测距传感器数据手册i2c
  • ¥15 RPA正常跑,cmd输入cookies跑不出来