题目描述

已知成绩表形成一个矩阵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));