我有一个生物完成开发的天数,以及每天完成开发的相应数量的生物。这些生物在不同的日子都开始发育,但不同年龄的生物可以在同一天完成发育。等。
Completion_day
22
23
23
23
24
数字已完成
124个
12
345个
7
231个
我的问题是如何总结在同一天完成的所有生物。当只有两个连续完成日相同时,这不是问题:我只是将'numbers_completed(i)添加到numbers_completed(i-1)'。但是,如果三组生物在同一天完成(例如上面的第23天),则第二天和第三天的总和将覆盖前两天的总和。有没有人对如何做到这一点有任何建议?
答案 0 :(得分:0)
假设您要添加与第23天相对应的“已完成的数字”(所以第2,第3和第4个条目),您可以使用find
函数来索引“完成日”中的位置它们出现的向量然后告诉MATLAB添加“已完成数字”向量的那些条目。
我将其实现为:
completion_day = [ 22 23 23 23 24]; % defining your variables
numbers_completed = [ 124 12 345 7 231]; % defining your variables
idx = find(completion_day == 23); % find the location of completion day 23
sum(numbers_completed(idx)) % return the sum of those 3 numbers
答案 1 :(得分:0)
只要矢量大小相同,您就可以跳过find
并使用逻辑索引。这是更短的代码,可能更快。
completionDay = [22 23 23 23 24];
numbersCompleted = [124 12 345 7 231];
sumCompleted = sum(numbersCompleted(completionDay == 23));
您可以使用以下内容循环完成唯一完成日期,并获取每天创建的总数
uniqueDays = unique(completionDays);
for i=1:length(uniqueDays)
sumCompleted(i) = sum(numbersCompleted(completionDay == uniqueDays(i)));
end