Sorted Matrix

You are given a matrix. The matrix elements are such that they are sorted both horizontally and vertically. Given an element of the matrix, your job is to obtain its position in an efficient manner.
Example:
10 20 30
15 35 98
48 76 110
Input: 76
Output: 3rd row, 2nd column.

Questions by hari_nowayout   answers by hari_nowayout

Showing Answers 1 - 15 of 15 Answers

rem132

  • Sep 2nd, 2008
 

Start at upper right corner and go in each step down or left depending of the result of comparison of current element and the element we search.

10 20 30
15 35 98
48 76 110
Input: 76
Output: 3rd row, 2nd column.

First start from extreme right-top and keep on seraching until you reach extreme left-down.

      n=0; m=0;

      while(n<3 && m<3){
          if(array[n][m]<desired){
              if(m>=2){
                 cout<<"Move Down :: ";
                 m = 2;
                 n++;
                 cout<<array[n][m]<<endl;
                 std::cin.get();
              }
              else{
                 if(array[n][m+1]>desired){
                    cout<<"Move Down :: ";
                    n++;
                    cout<<array[n][m]<<endl;
                    std::cin.get();
                 }
                 else{
                    cout<<"Move Left :: ";
                    m++;
                    cout<<array[n][m]<<endl;
                    std::cin.get();
                 }
              }
          }
          else
          if(array[n][m]>desired){
              if(m>=2){
                  m = 2;
              }
              cout<<"Move Right :: ";
              m--;
              cout<<array[n][m]<<endl;
              std::cin.get();
          }
          else{
              cout<<"FOUND:: "<<n+1<<" row, "<<m+1<<" column :: "<<array[n][m]<<endl;
              break;
          }
      }

  Was this answer useful?  Yes

aks3937

  • Jan 15th, 2009
 

in this Question our need is to find an element effeciently ,so i suggest one logic that can be implemented here are in 2 ways ... 1ST HORIZONTAL :->compare  1st and last element of every row with searching element and if the element lies in between the row , then search the element in that row or else go to next row until last row ..... similarly we can apply in VERTICAL way also......

logik

  • Apr 3rd, 2009
 

Check this one....

int SearchInArray( int **Arr, int Lower, int Upper)

{
 int middle = ( Lower + Upper )/2;
 int row     = middle/COL;
 int col       = middle%COL;

 if( Arr[row][col] == NumberToSearch )
  return middle;
 if( NumberToSearch < Arr[row][col] )
  return SearchInArray( Arr, Lower, middle - 1); 
 else return SearchInArray( Arr, middle + 1, Upper);
}

  Was this answer useful?  Yes

sabapc

  • Jul 12th, 2009
 

I'm assuming the matrix is NxM (not necessarily square) and there are no duplicate values (otherwise the search should return multiple results).

So that said, you can do the following:
1) go to the "center" of the matrix (dividing it in 4 quadrants)
2) if the value we're searching is smaller than the value at the center
      => we can discart the lower-right quadrant
      => we do recursive search on the other 3 quadrants
    if the value we're searching is greater than the value at the center
      => we can discart the upper-left quadrant
      => we do recursive search on the other 3 quadrants

// usage of the function
int[] result = find(value, matrix, 0, 0, N-1, M-1);

int[] find(int value, int[][] matrix, int i1, int j1, int i2, int j2) {
    if(i2<i1 || j2<j1)
        return null;
    if(i1==i2)
        return binary_search on row i1
    if(j1==j2)
        return binary_search on col j1

    // we go to the center of the matrix
    int i = (i1+i2)/2;
    int j = (j1+j2)/2;
    int midval = matrix[i][j];
    if(value==midval) {
        int[] solution = {i, j};
        return solution;
    }
    else if(value < midval) {
        // we discart lower-right quadrant
        int[] upleft = find(value, matrix, i1, j1, i-1, j-1);
        int[] upright = find(value, matrix, i1, j+1, i-1, j2);
        int[] lowleft = find(value, matrix, i+1, j1, i2, j-1);
        return upleft if(upleft != null);
        return upright if(upright != null);
        return lowleft if(lowleft != null);
        return null; // nothing found
    }
    else { // (value > midval)
        // we discart upper-left quadrant
        int[] upright = find(value, matrix, i1, j+1, i-1, j2);
        int[] lowleft = find(value, matrix, i+1, j1, i2, j-1);
        int[] lowright = find(value, matrix, i+1, j+1, i2, j2);
        return upright if(upright != null);
        return lowleft if(lowleft != null);
        return lowright if(lowright != null);
        return null; // nothing found
    }
}

I think that should do it.

About the order... you always reduce the solution space to 3/4, so the order should be logaritmic, but with a base smaller than 2, i.e. instead of something like log_2(n), it would be something like log_[1.33](n). This is clearly not a demonstration, just intuition.

complexity: O(LINE+COL)

class point
{
int x; int Y;
public:
point():x(-1),y(-1){}//constractor
setPoint(int x,intY){this->x=x;this->y=y;}
}

point SortedMatrix( int A[LINE][COL], int m)
{
int i=0,j=0;
point p = new point();
while(i<LINE) && (j<COL))
      {
         if(A[i][j]==m) {p.setPoint(i,j);return p;}
         if(A[i][j+1]==m) {p.setPoint(i,j+1);return p;}
         else if(A[i][j+1]<m) j++;
         if(A[i+1][j]==m) {p.setPoint(i+1,j);return p;}
         else if(A[i+1][j]<m) i++;
      }
return p;
}

#include

<iostream>

using

namespace std;

const

int max_size=50;

int

static x=0;

int

find(int matrix[max_size][max_size],int i,int j,int num)

{

while(num<matrix[x][j])

j--;

if(num==matrix[x][j])

{

cout<<

"found att"<<x<<","<<j<<"n";

return 0;

}

while (num<matrix[i][x])

i--;

if(num==matrix[i][x])

{

cout<<

"found att"<<i<<","<<x<<"n";

return 0;

}

x++;

if(x>i||x>j)

{

cout<<

"cannot find the numbern";

return -1;

}

return find(matrix,i,j,num);

}

int

main()

{

int matrix[max_size][max_size];

matrix[0][0] =34;

for(int i = 0;i<max_size;i++)

{

int r = rand();

if(i==0)

matrix[i][0]= r;

else

matrix[i][0] = matrix[i-1][0]+r;

for(int j=1;j<max_size;j++)

{

int r = rand();

matrix[i][j]=matrix[i][j-1]+r;

}

}

int

num =0;

cin>>num;

find(matrix,max_size,max_size,num);

}

  Was this answer useful?  Yes

anonymous

  • Jul 15th, 2011
 

Code
  1. #include<stdio.h>

  2. #include<stdlib.h>

  3. "enter the numbers in the sorted matrix

  4. Please enter such that the rows and columns are sorted

  5. Due to time constraint the check has not been given

  6. ");

  7.         scanf("%d""%d   ""

  8. the entered matrix is :::

  9. ""%d    ""

  10. ""enter the value which needs to be located

  11. ");

  12.  scanf("%d""the value is not present

  13. ""The value entered could not be located

  14. ""the location of the index value has been located at %dth row and %dth column

  15. ""enter the dimensions of the sqaure matrix

  16. ");

  17.  scanf("%d""do you want to locate more numbers ???

  18. 1.Yes

  19. 2.No

  20. ");

  21.  scanf("%d"

  Was this answer useful?  Yes

Jitendra Chittoda

  • Sep 4th, 2011
 

Start with the bottom left most corner and keep on checking the value.

# If the serchable item is greater then the item present in bottom most corner then it is confirmed that the item is present in this row only, then continue searching in same row until you find the item.
# else if the serchable item is less then the item present in bottom most corner then move up one and continue this process.

So the worst case complexity is O(m+n)

  Was this answer useful?  Yes

micheal

  • Sep 16th, 2011
 

Assume the matrix is M X N ,m=index for row and n=index for column, compare the last element(N-1) in each row wherever you find the first element bigger than the value you break out of the loop and then apply bsearch to the array a[m][N] where n =1 to n

Code
  1. #include<stdio.h>

  2. #include<conio.h>

  3. #define M 50

  4. #define N 50

  5. ");

  6. scanf("%d",&row);

  7. scanf("%d",&col);

  8. printf("ENTER THE VALUE OF THE MATRIX");

  9. for(m=0;m<row;m++)

  10. for(n=0;n<col;n++)

  11. scanf("%d",&a[m][n]);

  12. printf("

  13.  ENTER THE VALUE TO BE SEARCHED");

  14. scanf("%d",&value);

  15. for(m=0;m<row;m++)

  16. {

  17.   if(a[m][col-1]>=value)

  18.   break;

  19.  

  20. }

  21. n=col-1

  22. while(1)

  23. {

  24.   if(a[m][n]==value)

  25. {

  26. printf("%d

  27. %d",m,n);

  28. break;

  29. }

  30. else

  31.   if(a[m][n]>value)

  32.  {

  33.     n=n/2;

  34. }

  35. else

  36. if(a[m][n]<value)

  37. {

  38. n++;

  39. }

  40. }

  41. getch();

  42. }

  Was this answer useful?  Yes

raquelle

  • May 9th, 2012
 

I dont think you have to compare one from the other.. as I understand the problem.. what you have to do is to find the number in the matrix and know its location.. since the matrix is fix,. it is best to put it in a 2 dimensional array.. like matrix[x][y].. where x represents the row and y for the column.. by using for{} loop inside another for{} loop.. you can search for the inputted number and print x and y for position..

  Was this answer useful?  Yes

taruchu

  • Feb 10th, 2013
 

The algorithm will consist of a binary search on each column or on each row of the 2d matrix. By noting which column or row position you are doing the search on gives you the first index location in the 2d matrix. The second index is the exact location returned by the binary search in that column or row.

  Was this answer useful?  Yes

sandy

  • Mar 24th, 2013
 

I assume you can do it in the following way:

Code
  1. span style="font-style: italic;">##Look at the row

  2. " "

  Was this answer useful?  Yes

Give your answer:

If you think the above answer is not correct, Please select a reason and add your answer below.

 

Related Answered Questions

 

Related Open Questions