Information Security ˗ˋˏ ♡ ˎˊ˗

Programming/Programming 풀이

[Baekjoon] 18406번 럭키 스트레이트(C++)

토오쓰 2020. 10. 17. 18:18

 

https://www.acmicpc.net/problem/18406

 

18406번: 럭키 스트레이트

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

www.acmicpc.net

문제

현재 캐릭터의 점수를 N이라고 할 때, 점수 N을 자릿수 기준으로 반으로 나누어 왼쪽 부분의 각 자릿수의 합과 오른쪽 부분의 각 자릿수의 합을 더한 값이 동일한 상황을 의미한다.

예)

현재 점수가: 123,402라면 왼쪽 부분의 각 자릿수의 합은 1+2+3, 오른쪽 부분의 각 자릿수 합은 4+0+2이므로 두 합이 6으로 동일하여 럭키 스트레이트를 사용할 수 있다.

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

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

 

 

 

code

#include <iostream>
#include <string>
using namespace std;

int main() {
	string scores;
	cin >> scores;
	int sum1 = 0;
	int sum2 = 0;
	if (scores.size() % 2 == 0) {
		for (int i = 0; i < scores.size() /2; i++) {
			sum1 += scores[i];
		}
		for (int i = scores.size() / 2; i < scores.size(); i++) {
			sum2 += scores[i];
		}
		if (sum1 == sum2)
			std::cout << "LUCKY\n";
		else
			std::cout << "READY\n";
	}
	else std::cout << "FAIL\n";
	
}

 

 

결과