璀璨夜空 2023-10-08 13:47 采纳率: 100%
浏览 8
已结题

一个leetcode的Ruby二维数组问题

请问下面的Ruby代码最后一个测试返回的data数组为什么值都是4呢?

# @param {Integer[][]} mat
# @param {Integer} r
# @param {Integer} c
# @return {Integer[][]}
def matrix_reshape(mat, r, c)
  return mat if r * c != mat.count * mat[0].count
  data = Array.new(r, Array.new(c, 0))
  ii = 0
  jj = 0
  for i in 0...(mat.count)
    for j in 0...(mat[0].count)
      data[ii][jj] = mat[i][j]
      puts "#{ii}, #{jj} -> #{data[ii][jj]}"
      jj += 1
      if jj >= c 
        jj = 0
        ii += 1
      end
    end
  end
  
  for ii in 0...data.count
    for jj in 0...data[ii].count
      puts "#{ii}, #{jj} -> #{data[ii][jj]}"
    end
  end
  return data
end

for i, r in {[[[1,2],[3,4]], 1, 4] => [[1,2,3,4]], [[[1,2],[3,4]], 2, 4] => [[1,2],[3,4]], [[[1,2],[3,4]], 4, 1] => [[1],[2],[3],[4]]}
  a = matrix_reshape(i[0], i[1], i[2])
  puts "input: #{i}, output: #{a}, expected: #{r} -> #{a == r ? 'pass' : 'fail'}"
end

  • 写回答

1条回答 默认 最新

  • 专家-赤兔[在线] 全栈领域优质创作者 2023-10-09 06:21
    关注

    引自强大而免费的微信小程序:皆我百晓生。


    问题出在这一行代码 data = Array.new(r, Array.new(c, 0)) 中。在 Ruby 中,Array.new 的行为与预期可能不同,如果在 Array.new 中使用可变对象(如数组),则该对象会被共享,并在数组的每个位置上都是同一个对象的引用。

    因此,在你的代码中,data 数组的每个元素都是指向同一个内存引用的数组 [0, 0, 0, 0]。当你更新一个位置的值时,其他位置也会随之改变。

    要解决这个问题,你可以使用一个循环来创建 data 数组,并为每个位置都创建一个新的数组对象。以下是修改后的代码:

    def matrix_reshape(mat, r, c)
      return mat if r * c != mat.count * mat[0].count
      data = Array.new(r) { Array.new(c, 0) }  # 创建一个包含 r 个新数组的数组
      ii = 0
      jj = 0
      for i in 0...(mat.count)
        for j in 0...(mat[0].count)
          data[ii][jj] = mat[i][j]
          jj += 1
          if jj >= c 
            jj = 0
            ii += 1
          end
        end
      end
      
      return data
    end
    

    通过使用 Array.new(r) { Array.new(c, 0) },我们可以确保每个位置都得到一个新的数组对象。现在,测试应该返回预期的结果。

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

报告相同问题?

问题事件

  • 系统已结题 10月17日
  • 已采纳回答 10月9日
  • 创建了问题 10月8日

悬赏问题

  • ¥15 2020长安杯与连接网探
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)