콩부방

1476 : [기초-배열연습] 2차원 배열 빗금 채우기 3-1 본문

알고리즘 공부/CodeUp

1476 : [기초-배열연습] 2차원 배열 빗금 채우기 3-1

콩이아부지이 2021. 9. 9. 18:00
728x90

다음과 같은 n*m 배열 구조를 출력해보자.

입력이 3 4인 경우 다음과 같이 출력한다.
1 3 6 9
2 5 8 11
4 7 10 12

입력이 4 5인 경우는 다음과 같이 출력한다.
1 3 6 10 14
2 5 9 13 17
4 8 12 16 19
7 11 15 18 20

입력이 n m인 경우의 2차원 배열을 출력해보자.

입력

첫 번째 줄에 배열의 크기 n m이 입력된다.
[입력값의 정의역]
1<=  n,m <= 100

출력

n*m 크기의 배열을 설명과 같이 채워 출력한다.

입력 예시   예시 복사

2 3

출력 예시

1 3 5

2 4 6

 

import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int a = sc.nextInt();
		int b = sc.nextInt();
		int[][] c = new int[a][b];
		int d=1;
		int sum = a+b;
		for (int k = 0; k < sum; k++) { //입력값 3 4 일경우 6회전
			for (int i = 0; i < b; i++) {//3번반복
				for (int j = 0; j < a; j++) {//2번반복
					if(i+j == k) c[j][i]=d++;//k값 0,1,2,3,4,5 i+j값 더했을때 k값이랑 같을때가 [j][i]값이 배열에 들어가는 인덱스번호
				}
			}
		}
		for (int i = 0; i < a; i++) {
			for (int j = 0; j < b; j++) {
				System.out.print(c[i][j] + " ");
			}
			System.out.println();
		}
	}//main end 
}

 

 

 

 

728x90
Comments