题目描述
已知成绩表形成一个矩阵A,第1列为学号,第2列~第4列分别为数学、语文、英语成绩
现要求完成统计,按指定的排列方式进行输出。
输入1,对应数学降序输出
输入2,对应语文降序输出
输入3,对应英语降序输出
输入4,对应总分降序输出
A矩阵为:
1700201 98 86 83
1700202 85 90 78
1700203 92 78 95
1700204 88 88 85
1700205 78 95 88
输入
一行整数,表述按某种方式排序输出
输出
一个排列完成的矩阵
样例输入 Copy
1
样例输出 Copy
1700201 98 86 83 267
1700203 92 78 95 265
1700204 88 88 85 261
1700202 85 90 78 253
1700205 78 95 88 261
程序代码
A = [1700201, 98, 86, 83;
1700202, 85, 90, 78;
1700203, 92, 78, 95;
1700204, 88, 88, 85;
1700205, 78, 95, 88];
A = [A, sum(A(:,2:4), 2)];
n = input('');
switch n
case 1
[~,I]=sort(-A(:,2));
A = A(I,:);
case 2
[~,I]=sort(-A(:,3));
A = A(I,:);
case 3
[~,I]=sort(-A(:,4));
A = A(I,:);
case 4
[~,I]=sort(-A(:,5));
A = A(I,:);
end
disp(num2str(A));