[문제 설명] 

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

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

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

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

 

[입력]

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

[출력]

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

 

[입력 예시]

2 3

[출력 예시]

6 5 4

1 2 3

 

[코드]

#include<stdio.h>
int a[100][100];

int main() {
	
	int n, m, i, j, cnt;

	scanf("%d %d", &n, &m);

	for (i = 0; i < n; i++) {
		if(n % 2 == 0)
			if (i % 2 == 0)
				cnt = (n - i) * m;
			else
				cnt = (n-i) * m - (m-1);
		else
			if (i % 2 == 1)
				cnt = (n - i) * m;
			else
				cnt = (n - i) * m - (m - 1);
		for (j = 0; j < m; j++) {
			a[i][j] = cnt;
			if(n % 2 == 0)
				if (i % 2 == 0)
					cnt--;
				else
					cnt++;
			else
				if (i % 2 == 0)
					cnt++;
				else
					cnt--;
		}
	}

	for (i = 0; i < n; i++) {
		for (j = 0; j < m; j++)
			printf("%d ", a[i][j]);
		printf("\n");
	}

	return 0;
}

 

+ Recent posts