View
jungol.co.kr/bbs/board.php?bo_table=pbank&wr_id=2072&sca=20
JUNGOL
www.jungol.co.kr


Scanner sc = new Scanner(System.in);
int n = sc.nextInt(); // 정사각형 한 변의 길이
if (n > 100 || n < 1) {
System.out.println("INPUT ERROR");
n = sc.nextInt();
}
char[][] arr = new char[n][n];
char value = 'A'; // A부터 증가
입력받는 n의 범위는 1 이상 100 이하로 지정해주고, 2차원 배열을 선언한다.
for (int j = 0; j < n; j++) {
if (j % 2 != 0) {
for (int i = n - 1; i >= 0; i--) {
arr[i][j] = value++;
if (value == '[') {
value = 'A';
}
}
} else {
for (int i = 0; i < n; i++){
arr[i][j] = value++;
if (value == '[') {
value = 'A';
}
}
}
}
i : 행 / j : 열
0열부터 n열까지 ~
홀수 열 (1열, 3열 .. n-1열) : 역순으로 증가
짝수 열 (0열, 2열 .. n열) : 순차적으로 증가
굉장히 헷갈렸는데 0은 짝수니까 else문으로 출력된다고 생각하면 된다.
1은 홀수니까 if문으로 출력.. 이런식으로 번갈아가며 출력된다.
그리고 문자 찍다가 [ 문자 나오면 value 값을 다시 A로 넣어준다.
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
System.out.print(arr[i][j] + " ");
}
System.out.println();
}
arr[i][j] -> i행 j열 출력

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
|
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt(); // 정사각형 한 변의 길이
if (n > 100 || n < 1) {
System.out.println("INPUT ERROR");
n = sc.nextInt();
}
char[][] arr = new char[n][n];
char value = 'A'; // A부터 증가
for (int j = 0; j < n; j++) {
if (j % 2 != 0) {
for (int i = n - 1; i >= 0; i--) {
arr[i][j] = value++;
if (value == '[') {
value = 'A';
}
}
} else {
for (int i = 0; i < n; i++){
arr[i][j] = value++;
if (value == '[') {
value = 'A';
}
}
}
}
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
System.out.print(arr[i][j] + " ");
}
System.out.println();
}
}
}
|
cs |
'Jungol' 카테고리의 다른 글
[Beginner] 2046 : 숫자사각형4 (0) | 2021.01.26 |
---|---|
[Beginner] 1303 : 숫자사각형1 (0) | 2021.01.17 |
[Beginner] 1341 : 구구단2 (0) | 2021.01.15 |
[Beginner] 1291 : 구구단 (0) | 2021.01.13 |