## DEV Community is a community of 765,064 amazing developers

We're a place where coders share, stay up-to-date and grow their careers.

Atharva Siddhabhatti

Posted on

# Tech Mahindra "Student Report" Recruitment Exam Question

## Statement :-

Given a list of N students, every student is marked for M subjects. Each student is denoted by an index value. Their teacher Ms. Margaret must ignore the marks of any 1 subject for every student. For this she decides to ignore the subject which has the lowest class average.
Your task is to help her find that subject, calculate the total marks of each student in all the other subjects and then finally return the array of the total marks scored by each student.

Input Specification:
input1:
An integer value N denoting number of students

input2:
An integer value M denoting number of subjects

input3:
A 2-D integer array of size N'M containing the marks of all students in each subject.

Output Specification:

Return an integer array of size N containing the total marks of each student afte deducting the score for that one subject.

### Example 1:

INPUT

``````3 5
75 76 65 87 87
78 76 68 56 89
67 87 78 77 65
``````

OUTPUT

``````325 299 296
``````

### Example 2:

INPUT

``````3 3
50 30 70
30 70 99
99 20 30
``````

OUTPUT

``````120 129 129
``````

Explanation:

Out of these subjects, the students average was lowest in subject 2
i.e 30+70+20= 120/3=40

So the teacher will ignore marks of this subject and will consider the title other two subjects for each of the three students i.e. 120 129 129 respectively

Hence (120 129 129) is returned as the final output.

Solution:-

``````import java.util.Scanner;

public class MyClass {
public static void main(String args[]) {
Scanner sc = new Scanner(System.in);
int noOfStudents = sc.nextInt();
int noOfSubjects = sc.nextInt();
int index=0;
int[] avg = new int[noOfSubjects];
int[] total = new int[noOfSubjects];
int[] result = new int[noOfStudents];
int[][] marks = new int[noOfStudents][noOfSubjects];

for(int i=0;i<noOfStudents;i++)
{
for(int j=0;j<noOfSubjects;j++) {
marks[i][j] = sc.nextInt();
}
}
for(int i=0;i<noOfSubjects;i++)
{
for(int j=0;j<noOfStudents;j++) {
total[i] += marks[j][i];

}
}
for(int j=0;j<noOfSubjects;j++) {
//  System.out.print(total[j]+" ");
}
// System.out.println("");
for(int j=0;j<noOfSubjects;j++) {
avg[j] = total[j]/noOfSubjects;

//  System.out.print(avg[j]+" ");
}
int min = avg[0];

for(int i = 0; i < avg.length; i++)
{
if(min > avg[i])
{
min = avg[i];
index=i;
}
}
//  System.out.println(index);

for(int i=0;i<noOfStudents;i++)
{
for(int j=0;j<noOfSubjects;j++) {
if(j!=index) {
result[i] += marks[i][j];

}
}
}
for(int j=0;j<result.length;j++) {
System.out.print(result[j]+" ");
}

}
}
``````