6321번 : IBM 빼기 1
문제 )
'2001: 스페이스 오디세이'는 아서 C. 클라크의 소설이자 스탠리 큐브릭 감독의 영화이다.
이 작품에서 우주선은 토성으로 가고 있다. 긴 여행동안 선원들은 모두 정체 상태에 빠져있고, 두 선원은 깨어나 있다. 우주선은 인공지능 컴퓨터 HAL이 조정하고 있다. HAL은 점점 이상하게 행동하더니 선원들을 죽이기 시작했다. 자세한 이야기는 소설을 읽거나 영화를 보면 알 수 있다.
영화가 유명해지고 난 이후에 사람들은 '2001: 스페이스 오디세이'에 나오는 인공지능 컴퓨터인 HAL의 뜻에 관심을 가졌다. HAL은 휴리스틱 알고리즘 (Heuristic ALgorithm)의 약자이다. 하지만, HAL의 각 글자를 알파벳 다음 순서로 쓰면 IBM이 되기 때문에, IBM과 연관이 있다고 믿는 사람이 매우 많다.
컴퓨터의 이름이 주어졌을 때, 각 글자를 알파벳 다음 순서로 써서 출력하는 프로그램을 작성하시오.
입력 :
첫째 줄에 컴퓨터의 개수 n이 주어진다. 다음 줄부터 n개의 줄에는 컴퓨터의 이름이 주어진다. 컴퓨터의 이름은 최대 50글자이며, 알파벳 대문자로만 이루어져 있다.
출력 :
입력으로 주어진 컴퓨터 이름에 대해서, 한 줄에 하나씩 각 글자를 알파벳 다음 순서로 써서 출력한다. 각각의 컴퓨터 이름 사이에는 빈 줄을 하나씩 출력한다.
알파벳 Z의 다음 순서는 A이다.
풀이)
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
|
#include <iostream>
#include <string>
using namespace std;
int main()
{
int n;
string word;
cin >> n;
for (int i = 0; i < n; i++) {
cin >> word;
cout << "String #" << i + 1 << "\n";
for (int j = 0; j < word.length(); j++) {
// 'Z'의 경우 1을 더할때 A가 아닌 다른 코드가 나오므로,
if (word[j] == 'Z') {
cout << 'A';
continue;
}
cout << char(word[j] + 1);
}
cout << "\n\n";
}
return 0;
}
|
cs |
출처 : https://www.acmicpc.net/problem/6321
6321번: IBM 빼기 1
첫째 줄에 컴퓨터의 개수 n이 주어진다. 다음 줄부터 n개의 줄에는 컴퓨터의 이름이 주어진다. 컴퓨터의 이름은 최대 50글자이며, 알파벳 대문자로만 이루어져 있다.
www.acmicpc.net
'Develop > 백준 (Cpp)' 카테고리의 다른 글
[백준] 8974번 : 희주의 수학시험 (C++) (0) | 2023.02.06 |
---|---|
[백준] 10813번 : 공 바꾸기 (C++) (0) | 2023.02.06 |
[백준] 4892번 : 숫자 맞추기 게임 (C++) (0) | 2023.02.06 |
[백준] 4880번 : 다음수 (C++) (0) | 2023.02.06 |
[백준] 10874번 : 이교수님의 시험 (C++) (0) | 2023.02.06 |