Coding Challenge Day 7: Problem 3: Convert given Matrix into sorted Spiral Matrix

Hello! So I’m doing a 30 day coding challenge where I solve around 3-5 questions per day and thought of posting them here on my blog so that you guys can join the challenge too!

Welcome to Coding challenge Day 7: Problem 3! Be sure to post your answers, queries etc in the comments!

Problem: Convert given Matrix into sorted Spiral Matrix

Sample: Original Matrix: { { 4, 6, 15, 11 },
{ 1, 8, 9, 14 },
{ 2, 12, 5, 10 },
{ 3, 16, 7, 13 } }
Output: 1 2 3 4
12 13 14 5
11 16 15 6
10 9 8 7

Solution:

package array;

public class Program007spiral_matrix_sorted_arrange {

	public static void spiral_matrix (int [] sorted, int [][] spiral, int index, int row, int col, int circle){
		if(index>=(row*col))
			return;
		
		for(int i=circle; i<(col-circle); i++){
			spiral[circle][i]= sorted[index];
			index++;
		}
		
		if(index>= (row*col)){
			return;
		}
		
		for(int i=circle+1; i<row-circle; i++){
			spiral[i][col-1-circle]= sorted[index];
			index++;
		}
		
		if(index>=(row*col)){
			return;
		}
		
		for(int i=circle; i<col-circle-1; i++){
			spiral[row-circle-1][col-i-1-1]= sorted[index];
			index++;
		}
		
		if(index>=(row*col)){
			return;
		}
		
		for(int i=circle+1; i<row-circle-1; i++){
			spiral[row-circle-i-1][circle]=sorted[index];
			index++;
		}
		
		if(index>=(row*col)){
			return;
		}
		
		circle++;
		for(int i=0; i<row; i++){
			for(int j=0; j<col; j++){
				System.out.printf("%2d", spiral[i][j]);
			}
			System.out.println();
		}
		
		spiral_matrix (sorted, spiral, index, row, col, circle);
		
	}
	
	
	public static void main(String[] args) {

		int[][] matrix1 = { { 4, 6, 15, 11 }, { 1, 8, 9, 14 },
				{ 2, 12, 5, 10 }, { 3, 16, 7, 13 } };
		int n = 16, row = 4, col = 4, z = 0;
		int[] sorted = new int[n];
		int spiral[][] = new int[row][col];

		// covert unsorted matrix to 1d array
		for (int l = 0; l < row; l++) {
			for (int k = 0; k < col; k++) {
				sorted[z++] = matrix1[l][k];
			}
		}

		// Bubble Sort
		for (int i = 0; i < n; i++) {
			for (int j = 0; j < n - i - 1; j++) {
				if (sorted[j] > sorted[j + 1]) {
					int temp = sorted[j];
					sorted[j] = sorted[j + 1];
					sorted[j + 1] = temp;
				}
			}
		}
		
		spiral_matrix (sorted, spiral, 0, row, col, 0);
		
		for(int i=0; i < row; i++) {
            for(int j=0; j < col; j++) {
                System.out.printf("%2d ",spiral[i][j]);
            }
            System.out.println();
		}

	}

}

Download Code

Happy Learning!!

Leave a Reply

PHP JS HTML CSS BASH PYTHON CODE

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.

%d bloggers like this:
search previous next tag category expand menu location phone mail time cart zoom edit close