[백준 1855] 암호 (C#, C++) - soo:bak
작성일 :
문제 링크
설명
지그재그 형태로 문자를 배열한 후, 열 방향으로 읽어 원래의 문자열을 복원하는 문제입니다.
문자열은 입력으로 주어진 열 개수에 따라 위에서 아래로, 왼쪽에서 오른쪽, 또는 오른쪽에서 왼쪽으로 번갈아 가며 채워집니다.
이후 열 단위로 위에서 아래 방향으로 읽었을 때 복원되는 문자열을 계산합니다.
예를 들어, 열이 3
이고 암호 문자열이 "aeijfbcgklhd"
인 경우, 다음과 같은 순서로 채워집니다:
1
2
3
4
a e i
j f b
c g k
l h d
이를 위에서 아래로 열 기준으로 읽으면 "abcdefghijkl"
이 됩니다.
접근법
- 암호 문자열을 열 개수에 따라
행 x 열
형태로 나누고, - 짝수 번째 행은 왼쪽에서 오른쪽, 홀수 번째 행은 오른쪽에서 왼쪽 방향으로 채워줍니다.
- 이후 열 기준으로 위에서 아래로 문자열을 읽어 원래 문자열을 복원합니다.
Code
C#
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
using System;
using System.Text;
class Program {
static void Main() {
int col = int.Parse(Console.ReadLine());
string code = Console.ReadLine();
int row = code.Length / col;
char[,] table = new char[row, col];
int idx = 0;
for (int r = 0; r < row; r++) {
if (r % 2 == 0) {
for (int c = 0; c < col; c++)
table[r, c] = code[idx++];
} else {
for (int c = col - 1; c >= 0; c--)
table[r, c] = code[idx++];
}
}
var sb = new StringBuilder();
for (int c = 0; c < col; c++)
for (int r = 0; r < row; r++)
sb.Append(table[r, c]);
Console.WriteLine(sb.ToString());
}
}
C++
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
#include <bits/stdc++.h>
using namespace std;
typedef vector<char> vc;
typedef vector<vc> vvc;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int col; string code; cin >> col >> code;
int row = code.size() / col;
vvc table(row, vc(col));
for (int r = 0, i = 0; r < row; r++) {
for (int c = 0; c < col; c++)
table[r][r % 2 ? col - 1 - c : c] = code[i++];
}
for (int c = 0; c < col; c++) {
for (int r = 0; r < row; r++)
cout << table[r][c];
}
cout << "\n";
return 0;
}