如何找到R中矩阵的每一列的最大值?
为了找到矩阵每一列的最大值,我们需要使用apply函数。例如,如果我们有一个包含2行和2列的矩阵M,第一行的值为1、2,第二行的值为3、4,则可以通过使用来找到该矩阵中每一列的最大值语法; apply(M,2,max),因此结果将为3,4。
示例
M1−-matrix(1:36,ncol=6)M1
输出结果
[,1] [,2] [,3] [,4] [,5] [,6][1,] 1 7 13 19 25 31
[2,] 2 8 14 20 26 32
[3,] 3 9 15 21 27 33
[4,] 4 10 16 22 28 34
[5,] 5 11 17 23 29 35
[6,] 6 12 18 24 30 36
示例
apply(M1,2,max)
输出结果
[1] 6 12 18 24 30 36
示例
M2<-matrix(1:100,ncol=10)M2
输出结果
[,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10][1,] 1 11 21 31 41 51 61 71 81 91
[2,] 2 12 22 32 42 52 62 72 82 92
[3,] 3 13 23 33 43 53 63 73 83 93
[4,] 4 14 24 34 44 54 64 74 84 94
[5,] 5 15 25 35 45 55 65 75 85 95
[6,] 6 16 26 36 46 56 66 76 86 96
[7,] 7 17 27 37 47 57 67 77 87 97
[8,] 8 18 28 38 48 58 68 78 88 98
[9,] 9 19 29 39 49 59 69 79 89 99
[10,] 10 20 30 40 50 60 70 80 90 100
示例
apply(M2,2,max)
输出结果
[1] 10 20 30 40 50 60 70 80 90 100
示例
M3<-matrix(sample(rnorm(10),25,replace=TRUE),ncol=5)M3
输出结果
[,1] [,2] [,3] [,4] [,5][1,] -0.8410610 -0.8410610 -1.1271937 -0.8410610 -0.1262492
[2,] -1.1271937 -0.3367099 -0.8410610 -0.2109494 -0.2109494
[3,] -0.1262492 -1.0366269 -0.2109494 -0.3367099 -0.2109494
[4,] -0.2109494 -0.3367099 -0.3367099 -0.3367099 -1.9793046
[5,] -1.2250289 -0.1262492 -0.1262492 -1.0366269 -1.1271937
示例
apply(M3,2,max)
输出结果
[1] -0.1262492 -0.1262492 -0.1262492 -0.2109494 -0.1262492
示例
M4<-matrix(sample(rnorm(100,10,1),25),ncol=5)M4
输出结果
[,1] [,2] [,3] [,4] [,5][1,] 8.880632 9.932590 12.152003 10.745158 12.644492
[2,] 8.743728 9.223513 9.937427 9.327102 9.490583
[3,] 7.502350 10.231251 9.350336 10.823048 9.282358
[4,] 9.830723 9.045965 10.197617 9.194218 9.420975
[5,] 9.974345 10.835077 9.982087 10.112384 9.404278
示例
apply(M4,2,max)
输出结果
[1] 9.974345 10.835077 12.152003 10.823048 12.644492
示例
M5<-matrix(sample(rpois(100,10),64),ncol=8)M5
输出结果
[,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8][1,] 16 4 9 9 10 5 15 9
[2,] 3 6 11 6 15 17 5 9
[3,] 7 10 9 6 16 14 6 2
[4,] 12 10 9 5 10 9 7 11
[5,] 11 9 10 9 12 10 17 6
[6,] 11 10 7 10 9 12 8 9
[7,] 11 7 6 11 8 9 9 8
[8,] 9 12 12 9 12 12 14 12
示例
apply(M5,2,max)
输出结果
[1] 16 12 12 11 16 17 17 12
示例
M6<-matrix(sample(1:10,100,replace=TRUE),ncol=10)M6
输出结果
[,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10][1,] 7 1 7 3 5 7 8 7 10 4
[2,] 6 9 7 4 6 5 5 10 9 7
[3,] 10 4 2 2 8 9 9 4 4 1
[4,] 3 1 7 3 3 7 10 8 7 4
[5,] 5 10 7 8 10 3 5 1 8 4
[6,] 7 3 10 4 5 1 5 5 3 4
[7,] 6 4 4 2 1 9 3 6 6 2
[8,] 10 4 2 8 6 10 6 2 5 8
[9,] 6 9 10 7 3 4 6 6 5 4
[10,] 7 10 5 3 6 7 3 8 9 2
示例
apply(M6,2,max)
输出结果
[1] 10 10 10 8 10 10 10 10 10 8
示例
M7<-matrix(sample(runif(10,2,5),25,replace=TRUE),ncol=5)M7
输出结果
[,1] [,2] [,3] [,4] [,5][1,] 2.637646 4.744968 3.122147 4.563885 4.744968
[2,] 3.418107 2.637646 3.331060 3.122147 2.845479
[3,] 2.190630 3.331060 2.637646 2.190630 4.834246
[4,] 4.834246 4.563885 2.845479 2.845479 3.418107
[5,] 2.845479 2.190630 2.190630 4.744968 2.637646
示例
apply(M7,2,max)
输出结果
[1] 4.834246 4.744968 3.331060 4.744968 4.834246
示例
M8<-matrix(sample(5001:9999,64),ncol=8)M8
输出结果
[,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8][1,] 5294 5567 9539 5907 9808 6692 6810 9809
[2,] 9005 5150 9502 7604 8849 8504 6631 6261
[3,] 6694 5162 7813 5995 9684 8647 7094 9828
[4,] 5055 7450 7588 8006 8480 5145 9741 8959
[5,] 8300 5964 8411 6109 5320 8649 5777 9473
[6,] 9054 5585 7304 6827 6231 5199 8518 8958
[7,] 5912 8356 6741 9949 6363 9488 7093 6813
[8,] 6312 7701 5741 6947 6012 6579 6873 7793
示例
apply(M8,2,max)
输出结果
[1] 9054 8356 9539 9949 9808 9488 9741 9828
以上是 如何找到R中矩阵的每一列的最大值? 的全部内容, 来源链接: utcz.com/z/354253.html