[백준 | 파이썬] 15904 : UPCP는 무엇의 약자일까?

devheyrin·2022년 2월 28일
0

codingtest

목록 보기
17/65
💡 반례를 생각하지 못하면 까다로울 수 있는 문제

문제

UCPC는 '전국 대학생 프로그래밍 대회 동아리 연합 여름 대회'의 줄임말로 알려져있다. 하지만 이 줄임말이 정확히 어떻게 구성되었는지는 아무도 모른다. UCPC 2018을 준비하던 ntopia는 여러 사람들에게 UCPC가 정확히 무엇의 줄임말인지 물어보았지만, 아무도 정확한 답을 제시해주지 못했다. ntopia가 들은 몇 가지 답을 아래에 적어보았다.

  • Union of Computer Programming Contest club contest
  • Union of Computer Programming contest Club contest
  • Union of Computer Programming contest club Contest
  • Union of Collegiate Programming Contest club contest
  • Union of Collegiate Programming contest Club contest
  • Union of Collegiate Programming contest club Contest
  • University Computer Programming Contest
  • University Computer Programming Club contest
  • University Computer Programming club Contest
  • University Collegiate Programming Contest
  • University CPC
  • ...

ntopia는 이렇게 다양한 답을 듣고는 UCPC가 무엇의 약자인지는 아무도 모른다고 결론내렸다. 적당히 슥삭해서 UCPC를 남길 수 있으면 모두 UCPC의 약자인 것이다!

문자열이 주어지면 이 문자열을 적절히 축약해서 "UCPC"로 만들 수 있는지 확인하는 프로그램을 만들어보자.

축약이라는 것은 문자열에서 임의의 문자들을 제거하는 행동을 뜻한다. 예를 들면, "apple"에서 a와 e를 지워 "ppl"로 만들 수 있고, "University Computer Programming Contest"에서 공백과 소문자를 모두 지워 "UCPC"로 만들 수 있다.

문자열을 비교할 때는 대소문자를 구분해 정확히 비교한다. 예를 들어 "UCPC"와 "UCpC"는 다른 문자열이다. 따라서 "University Computer programming Contest"를 "UCPC"로 축약할 수 있는 방법은 없다.

그나저나 UCPC는 정말 무엇의 약자였을까? 정확히 아시는 분은 제보 부탁드립니다.

풀이 방법

금방 풀 거라고 생각했는데 계속 틀려서 결국 구글링해서 힌트를 얻었다

DUCPC, UCDPDC 같이 중간에 다른 대문자가 껴 있어도 이것들을 모두 제외시켰을 때 UCPC 가 될 수만 있으면 I love UCPC 를 출력해야 한다.

이 반례를 생각 못해서 풀이가 좀 까다로웠다.

  • U, C, P, C 로 구성된 배열을 만든다.
  • 배열을 돌면서 배열 안의 알파벳이 문장 안에도 있으면 그 바로 다음 인덱스부터 문장 끝까지 잘라서 새 문장을 만든다.
  • 새로 만들어진 문장에 대해 반복한다.
  • U, C, P, C 중 하나라도 문장 안에 없으면 break 로 반복문을 중단한다.

코드

sentence = input()
check_list = ['U', 'C', 'P', 'C']
check = True
for i in range(len(check_list)):
    if check_list[i] in sentence:
        idx = sentence.index(check_list[i])
        sentence = sentence[idx + 1:]  # 바로 다음 문자열부터 끝까지
        check = True
    else:
        check = False
        break;

if check:
    print('I love UCPC')
else:
    print('I hate UCPC')
profile
개발자 헤이린

0개의 댓글