账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    树状数组取出ID为3的项,方法越简单越好,求解
    68
    0
    const floor = [
      {
        id: 1,
        text: '一层',
        children: [
          {
            id: 2,
            text: '二层',
            children: [
              {
                id: 3,
                text: '三层',
                children: [
                  {
                    id: 4,
                    text: '四层'
                  }
                ]
              }
            ]
          }
        ]
      }
    ];
    0
    打赏
    收藏
    点击回答
        全部回答
    • 0
    • 殘缺、的愛 普通会员 1楼

      你可以使用哈希表来快速查找第3个元素。假设你的树状数组的每个元素都是一个哈希表的键,其中键是元素的ID,值是元素本身。那么你可以使用以下方法来找到第3个元素:

      1. 遍历整个树状数组。
      2. 如果当前元素的ID等于第2个元素的ID,那么找到第3个元素。
      3. 如果当前元素的ID大于第2个元素的ID,那么查找下一个元素。
      4. 如果当前元素的ID小于第2个元素的ID,那么查找下一个元素,直到找到第3个元素。

      这个方法的时间复杂度是O(n),其中n是树状数组的长度。这是因为我们只需要遍历一次整个树状数组。

      下面是使用Python实现的代码:

      ```python def findThirdElement(arr): if len(arr) == 0: return None

      # 哈希表,用于存储元素的ID和值
      hash_table = {}
      
      # 遍历整个树状数组
      for i in range(len(arr)):
          # 如果当前元素的ID等于第2个元素的ID
          if arr[i]['id'] == arr[1]['id']:
              # 找到第3个元素
              return arr[i]
          # 如果当前元素的ID大于第2个元素的ID
          elif arr[i]['id'] > arr[1]['id']:
              # 查找下一个元素
              return findThirdElement(arr[i+1:])
          # 如果当前元素的ID小于第2个元素的ID
          else:
              # 查找下一个元素,直到找到第3个元素
              return findThirdElement(arr[i+1:])
      

      ```

      这个函数会返回一个哈希表,其中键是元素的ID,值是元素本身。

    更多回答
    扫一扫访问手机版
    • 回到顶部
    • 回到顶部