How to sum up unique arrays in the matrix

3 ビュー (過去 30 日間)
Moe
Moe 2016 年 4 月 4 日
編集済み: Azzi Abdelmalek 2016 年 4 月 4 日
Hi everyone,
Suppose the matrix A is as follows:
A = [10 1 180
10 1 40
10 1 40
10 1 160
10 2 10
10 3 410
10 1 10
10 1 50
12 1 30
12 1 30
12 2 45
12 3 60
65 1 15
65 1 360
];
I want to sum up the values in column three if the value in column one and two are similar. The output matrix should be like:
B = [10 1 420
10 2 10
10 3 410
10 1 60
12 1 60
12 2 45
12 3 60
65 1 375
];

採用された回答

Azzi Abdelmalek
Azzi Abdelmalek 2016 年 4 月 4 日
編集済み: Azzi Abdelmalek 2016 年 4 月 4 日
Edit
A = [10 1 180
10 1 40
10 1 40
10 1 160
10 2 10
10 3 410
10 1 10
10 1 50
12 1 30
12 1 30
12 2 45
12 3 60
65 1 15
65 1 360
];
idx=any([0 0;diff(A(:,1:2))],2)
jdy=cumsum(idx)
b=accumarray(jdy+1,1:numel(jdy),[],@(x) sum(A(x,3)))
[ii,jj,kk]=unique(jdy)
out=[A(jj,1:2) b]

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeMultidimensional Arrays についてさらに検索

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by