1

我有以下数据:

a b c d
5 9 6 0
3 1 3 2

第一行是字符,第二行是数字。

如何获取第二行中最大数字对应的字符,以及如何增加第二行中对应的数字?(例如,在这里,列b的数字最大9,所以将该数字增加 10%。)

我使用 Dyalog 17.1 版。

4

1 回答 1

1

和:

      ⎕←data←3 4⍴'a' 'b' 'c' 'd' 5 9 6 0 3 1 3 2
a b c d
5 9 6 0
3 1 3 2

您可以使用以下方法提取第二行:

      2⌷data
5 9 6 0

现在对其进行降序评分,即找到将其从最高到最低排序的索引:

      ⍒2⌷data
2 3 1 4

第一个数字是我们要查找的列:

      ⊃⍒2⌷data
2

现在我们可以使用它从第一行中提取字符:

      data[⊂1,⊃⍒2⌷data]
b

但我们只需要列索引,而不需要实际字符。我们要增加的数字的完整索引是:

     2,⊃⍒2⌷data
2 2

提取数据看看我们得到了正确的索引:

      data[⊂2,⊃⍒2⌷data]
9

现在我们可以创建一个目标值增加 10% 的新数组:

      1.1×@(⊂2,⊃⍒2⌷data)⊢data
a   b c d
5 9.9 6 0
3 1   3 2

或者就地改变它:

      data[⊂2,⊃⍒2⌷data]×←1.1
      data
a   b c d
5 9.9 6 0
3 1   3 2

在线尝试!

于 2020-02-23T09:22:09.337 回答