Friday, 3 July 2015

Triangular Matrix

In this assignment, you will be given an NxN matrix. You have to determine whether the matrix is a triangular matrix.

The diagonal of the matrix M of size NxN is the set of entries M(0,0), M(1,1), M(2,2), ..., M(N,N).

A matrix is upper triangular if every entry below the diagonal is 0. For example, 
1 1 1
0 0 1
0 0 2
is an upper triangular matrix. (The diagonal itself, and the entries above and below the diagonals can be zeroes or non-zero integers.)

A matrix is lower triangular if every entry above the diagonal is 0. For example,
2 0 0
3 1 0
4 2 2
is a lower triangular matrix. 

A matrix is triangular if it is either upper triangular or lower triangular. 

You may not use arrays for this program.

Input
First, you will be given N, which is the size of the matrix.

Then you will be given N rows of integers, where each row consists of N integers separated by spaces.

Output
If the input matrix is triangular, then print yes. Otherwise, print no.

/*CODE*/
#include<stdio.h>
int main()
{
int N,i,j,count1=0,count2=0,temp;
scanf("%d",&N);
int num[N][N];
for(i=0;i<N;i++)
{
for(j=0;j<N;j++)
{
scanf("%d",&num[i][j]);
}
}
for(i=0;i<N;i++)
{
for(j=0;j<N;j++)
{
if(i<j)
{
if(num[i][j]==0)
count1++;
}
if(i>j)
{
if(num[i][j]==0)
count2++;
}
}
}
temp=N*N;
if(count1==(temp-N)/2)
{
printf("yes");
return 0;
}
if(count2==(temp-N)/2)
{
printf("yes");
return 0;
}
printf("no");
return 0;
}

1 comment:

  1. i have tried ur coding , it works but gives me the score of 75/100 ..
    not able to make it 100

    ReplyDelete