我有以下数据:
a b c d
5 9 6 0
3 1 3 2
第一行是字符,第二行是数字。
如何获取第二行中最大数字对应的字符,以及如何增加第二行中对应的数字?(例如,在这里,列b
的数字最大9
,所以将该数字增加 10%。)
我使用 Dyalog 17.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