[C언어 코드업 문제풀이] CodeUp 1478 : [기초-배열연습] 2차원 배열 빗금 채우기 3-3
ET의 공부/C언어 연습문제[ 코드업 ]2020. 5. 3. 09:10
코드업 1478번 2차원 배열 빗금 채우기 3-3 문제 풀이 해답입니다.
1. 문제 설명
다음과 같은 n*m 배열 구조를 출력해보자.
입력이 3 4인 경우 다음과 같이 출력한다.
7 4 2 1
10 8 5 3
12 11 9 6
입력이 4 5인 경우는 다음과 같이 출력한다.
11 7 4 2 1
15 12 8 5 3
18 16 13 9 6
20 19 17 14 10
입력이 n m인 경우의 2차원 배열을 출력해보자.
2. 입력
첫 번째 줄에 배열의 크기 n m이 입력된다.
[입력값의 정의역]
1<= n,m <= 100
3. 출력
n*m 크기의 배열을 설명과 같이 채워 출력한다.
4. 입력 예시
2 3
5. 출력 예시
4 2 1
6 5 3
6. 문제 풀이
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
#include "stdio.h"
int main(void)
{
int Arr[101][101] = {};
int n,m;
scanf("%d %d", &n, &m);
/*
11-(1,1)| 7-(1,2)| 4-(1,3)| 2-(1,4)| 1-(1,5)
--------------------------------------------
15-(2,1)|12-(2,2)| 8-(2,3)| 5-(2,4)| 3-(2,5)
--------------------------------------------
18-(3,1)|16-(3,2)|13-(3,3)| 9-(3,4)| 6-(3,5)
--------------------------------------------
20-(4,1)|19-(4,2)|17-(4,3)|14-(4,4)|10-(4,5)
*/
//대각선의 요소는 해당 요소가 (i,j)라면 (i-1, j-1),(i+1,j+1)
int x = 1;
int i = 1;
int j = m; //시작이 (1,m)에서 시작.
int temp_j = m;
int temp_i = 1;
for(int k = 1; k <=n*m; k++){
if( ( i >= 1 && i <= n) && ( j >= 1 && j <= m) ){
Arr[i][j] = x;
x++;
i++;
j++;
if( !(( i >= 1 && i <= n) && ( j >= 1 && j <= m)) ){ //대각선이 밑으로(범위밖)으로 나갔을때
temp_j--; //왼쪽으로 시작점 이동
if(temp_j <=0){ //범위 밖이면
temp_j = 1;
temp_i++; //왼쪽으로(범위밖) 더이상 갈 수 없으면 아래로 이동
}
i = temp_i;
j = temp_j;
}
}
}
for(int i = 1; i <= n; i++){
for(int j = 1; j <= m ; j++){
printf("%d ",Arr[i][j]);
}
printf("\n");
}
return 0;
}
|
'ET의 공부 > C언어 연습문제[ 코드업 ]' 카테고리의 다른 글
[C언어 코드업 문제풀이] CodeUp 1480 : [기초-배열연습] 2차원 배열 빗금 채우기 3-5 (0) | 2020.05.03 |
---|---|
[C언어 코드업 문제풀이] CodeUp 1479 : [기초-배열연습] 2차원 배열 빗금 채우기 3-4 (0) | 2020.05.03 |
[C언어 코드업 문제풀이] CodeUp 1477 : [기초-배열연습] 2차원 배열 빗금 채우기 3-2 (0) | 2020.05.03 |
[C언어 코드업 문제풀이] CodeUp 1476 : [기초-배열연습] 2차원 배열 빗금 채우기 3-1 (1) | 2020.05.02 |
[C언어 코드업 문제풀이] CodeUp 1475 : [기초-배열연습] 2차원 배열 지그재그 채우기 2-8 (1) | 2020.05.02 |
댓글()