按一项对列表进行排序,并在 Netlogo 中识别满足条件的记录

Sort list by one item and identify record that meets a condition in Netlogo

我有一个子列表列表,如下所示

[[0 “煤” 500 1430] [0 “煤” 300 1300] [1 “煤” 600 1500] [1 “煤” 700 1400]]

我想做四件事:
1. 主列表按子列表第3项排序
2. 对子列表的第2项进行累加,直到达到某个值。
3. 确定最后添加的列表中的第 3 项。
4. 然后我想确定在第 2 点中添加到循环中的列表的项目 0 和 1,并要求这些海龟做一些事情。

我一直在探索表格、列表等,但一直在努力处理这些复杂的代码。人们可以建议他们如何编码吗?

在此先感谢您的帮助!

以下似乎可以回答这个问题,我认为......虽然可能有更优雅的方式

to go
  create-turtles 2
  let l [[0 "coal" 500 1430] [0 "gas" 300 1300] [1 "coal" 600 1500] [1 "gas" 700 1400]]
  ;sort the list by item 2 
  let sorted sort-by bigger l
  show sorted
  ;accumulate item 3 until limit reached
  let k 0
  let n 0
  let limit 2800
  let turtleNos []
  let fuels []
  while [k < limit]
  [
    set k k + item 3 ( item n sorted )
    ;accumulate item 0 and 1
    set turtleNos lput item 0 ( item n sorted ) turtleNos 
    set fuels lput item 1 ( item n sorted ) fuels 
    set n n + 1
  ]
  show k
  ;show item 3 for the last item added to k
  show item 3 (item ( n - 1 ) sorted)
  ;accumulated lists - note non-unique
  show turtleNos
  show fuels
  (foreach turtleNos fuels 
      [ [x y] -> ask turtle x [show y] ])

end
to-report bigger [l1 l2]
  report item 2 l1 > item 2 l2
end