我有一个简单的问题要问。 我尝试创建一个名为'passavg_structure'的函数,该函数将空域结构数组(将在下面显示)作为输入参数,并输出前往指定城市的平均乘客数量。
空域结构阵列如下所示:
>> airspace(1)
ans =
Flight_Number: 'BF 123'
Speed: 515.2000
Heading: 90
Passengers: 154
Crew: {'Behnam' 'Jane' 'Jill' 'Ning'}
Destination: 'Montreal'
Feet: 22000
Latitude_Longitude: [50 100]
>> airspace(2)
ans =
Flight_Number: 'VSO 456'
Speed: 99.6000
Heading: 270
Passengers: 270
Crew: {'Frances' 'Jake' 'Jaiwei'}
Destination: 'Los Angeles'
Feet: 21000
Latitude_Longitude: [50 80]
>> airspace(3)
ans =
Flight_Number: 'BF 8421'
Speed: 1.5057e+03
Heading: 170
Passengers: 0
Crew: {'Giuseppe' 'Susan'}
Destination: 'Calgary'
Feet: 33000
Latitude_Longitude: [60 80]
>> airspace(4)
ans =
Flight_Number: 'AB 896'
Speed: 500
Heading: 90
Passengers: 132
Crew: {'Hao' 'Ashraf' 'Sue'}
Destination: 'Montreal'
Feet: 33000
Latitude_Longitude: [50 100]
所以我要做的是遍历空域的名称,如果它等于函数的输入参数给出的名称,那么它将找到结构数组中名称出现的位置并添加乘客数量,然后除以名称的次数,以获得平均值。我的不完整代码如下:
function output = passavg_structure(airspace,name)
output = 0;
[a, b, c, d] = airspace(:).Destination;
for k = {a,b,c,d}
if strcmp(k,name) == 1
output = airspace().Passengers;
else
output = 0;
end
output = output/;
end
我迷失了如何找到关于匹配名称在结构数组中出现的位置。我觉得这是我的代码问题而且因为我不确定如何做到这一点它是不完整的。
例如,假设我们做了:
passavg_structure(airspace,'Montreal')
输出将是= 143,因为它增加了来自哪里的乘客 自蒙特利尔发生两次以来,蒙特利尔发生并将其除以2。
对此的任何帮助将不胜感激!
谢谢大家。
答案 0 :(得分:1)
您可以使用ismember
直接解决问题:
function out = passavg_structure(airspace, name)
out = mean([airspace(ismember({airspace(:).Destination}, name)).Passengers]);
和out
包含到达目的地的平均旅客人数name
。
最佳,
答案 1 :(得分:1)
mean([airspace(strcmpi({airspace(:).Destination},'Montreal')).Passengers])
从内到外
如果没有数据退出,则表示返回NaN