我想获得数组子集的总和、最大值和/或最小值。
在 SAS 中,您可以说:
x = max(of v5-v10);
其中 v5 到 v10 是变量
但是你不能说:
array v[20];
i = 5;
x = max(of v[i]-v[i+5];
它不明白 v[i]-v[i+5] 是一个变量范围。有没有其他方法可以做到这一点?
您可以遍历数组的元素:
数据最大值;
数组 v{20} ;
我 = 5 ;
最大 = 。;
做 n = i 到 i+5 ;
vmax = max(vmax,v{n}) ;
结尾 ;
跑 ;
或者创建一个只包含您需要的元素的新数组:
%让我 = 5 ;
数据最大值;
数组 v{*} v&I-v%EVAL(&I+5) ;
vmax = max(of v{*}) ;
跑 ;
您可以使用:
array a(*) _numeric_;
do i=1 to dim(a);
if a(i) = . then a(i) = 0; //this replaces mssing for 0´s but you can implement any logic here
end;
drop i;