Notice
Recent Posts
Recent Comments
Link
«   2025/10   »
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
Archives
Today
Total
관리 메뉴

코딩로그

[백준/BOJ/C++] 18406번 럭키 스트레이트 본문

YJ/C++

[백준/BOJ/C++] 18406번 럭키 스트레이트

Team DAON 2021. 10. 27. 16:17

[문제]

어떤 게임의 아웃복서 캐릭터에게는 럭키 스트레이트라는 기술이 존재한다. 이 기술은 매우 강력한 대신에 항상 사용할 수는 없으며, 현재 게임 내에서 점수가 특정 조건을 만족할 때만 사용할 수 있다.

특정 조건이란 현재 캐릭터의 점수를 N이라고 할 때 점수 N을 자릿수를 기준으로 반으로 나누어 왼쪽 부분의 각 자릿수의 합과 오른쪽 부분의 각 자릿수의 합을 더한 값이 동일한 상황을 의미한다. 예를 들어 현재 점수가 123,402라면 왼쪽 부분의 각 자릿수의 합은 1+2+3, 오른쪽 부분의 각 자릿수의 합은 4+0+2이므로 두 합이 6으로 동일하여 럭키 스트레이트를 사용할 수 있다.

현재 점수 N이 주어졌을 때, 럭키 스트레이트를 사용할 수 있는 상태인지 아닌지를 알려주는 프로그램을 작성하시오. 럭키 스트레이트를 사용할 수 있다면 "LUCKY"를, 사용할 수 없다면 "READY"라는 단어를 출력한다. 또한 점수 N의 자릿수는 항상 짝수 형태로만 주어진다. 예를 들어 자릿수가 5인 12,345와 같은 수는 입력으로 들어오지 않는다.

 

[입력]

첫째 줄에 점수 N이 정수로 주어진다. (10 ≤ N ≤ 99,999,999) 단, 점수 N의 자릿수는 항상 짝수 형태로만 주어진다.

 

[출력]

첫째 줄에 럭키 스트레이트를 사용할 수 있다면 "LUCKY"를, 사용할 수 없다면 "READY"라는 단어를 출력한다.

 

[Source Code]

#include <stdio.h>
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
using namespace std;

int main() {
	string input;
	int left = 0, right = 0;
	cin >> input;

	int length = input.length()/2 - 1;
	for(int i = 0; i <= length; i++){
		left += (int)input[i];
	}
	for(int i = length+1; i < input.length(); i++){
		right += (int)input[i];
	}
	
	if(left == right)
		cout << "LUCKY";
	else
		cout << "READY";
}

[결과 화면]

'YJ > C++' 카테고리의 다른 글

[백준/BOJ/C++] 10828번 스택  (0) 2021.10.27
[백준/BOJ/C++] 2774번 아름다운 수  (0) 2021.10.27
[백준/BOJ/C++] 2857번 FBI  (0) 2021.10.27
[백준/BOJ/C++] 5355번 화성 수학  (0) 2021.10.27
[백준/BOJ/C++] 1259번 팰린드롬수  (0) 2021.10.27