[BOJ/Python] 럭키 스트레이트 || 구현

2023. 4. 12. 12:46·🎯PS

백준 18406 럭키 스트레이트 파이썬

18406번: 럭키 스트레이트

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

www.acmicpc.net

더보기

❍ 문제

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

특정 조건이란 현재 캐릭터의 점수를 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"라는 단어를 출력한다.

 

❍ 예제

❏ 문제 풀이

문자열로 이루어진 점수를 입력받아서, 문자열의 길이를 토대로 반씩 나누어 각각의 리스트를 형성한다.
그 후, 각 리스트의 합을 구하여 비교하면 된다.

 

❍ Code

import sys

input = sys.stdin.readline

num = input()

num1 = num[:len(num)//2]
num2 = num[len(num)//2:]

sum1 = 0
sum2 = 0
for i in range(len(num)//2):
    sum1 += int(num1[i])
    sum2 += int(num2[i])

if sum1 == sum2:
    print("LUCKY")
else:
    print("READY")

메모리 : 31256KB, 시간 : 44ms

반응형
'🎯PS' 카테고리의 다른 글
  • [Programmers/Python] 자물쇠와 열쇠 || 구현
  • [Programmers/Python] 문자열 압축 || 구현
  • [Programmers/Python] 무지의 먹방 라이브 || 그리디, 우선 순위 큐, 최소 힙
  • [BOJ/Python] 1439번: 뒤집기 || 그리디, 문자열
dmaolon
dmaolon
프로그래밍을 공부한 내용을 기록하는 공간입니다.
  • dmaolon
    기록 남기기
    dmaolon
  • 전체
    오늘
    어제
    • ALL (260)
      • ➰ Series (5)
      • 🎯PS (168)
        • Algorithm (15)
      • ☕ Java (11)
      • 🍀 Spring Boot (29)
      • 💬 Database (9)
      • 🐣 Computer Science (14)
      • 👍 Daily (4)
      • 🎁ReactJS (4)
  • 인기 글

  • 최근 댓글

  • 최근 글

  • 태그

    프로그래머스
    프로그래밍
    파이썬
    BFS
    dfs
    코딩
    알고리즘
    자바
    백준
    Spring
  • hELLO· Designed By정상우.v4.10.1
dmaolon
[BOJ/Python] 럭키 스트레이트 || 구현
상단으로

티스토리툴바