티스토리 뷰

728x90

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

 

21966번: (중략)

알파벳 대문자, 알파벳 소문자, 쉼표, 마침표의 아스키 코드는 각각 65-90, 97-122, 44, 46이다.

www.acmicpc.net


  • 문제 : 

드높은 남산 위에 우뚝 선

(중략)

세워라 반석 위에

선린의 터를

 

1개 이상의 문장들이 주어진다. 아래 규칙에 따라 문장들의 중간 부분을 적당히 생략해 25글자 이내로 요약해서 출력하는 프로그램을 작성하자.

 

단, 입출력의 편의를 위해 문장들을 공백 없이 모두 붙여 구성한 문자열 S가 대신 주어진다. 문자열의 첫 글자부터 가장 먼저 만나는 '.'(마침표)까지, 그리고 각 '.'의 다음 글자부터 가장 먼저 만나는 '.'까지를 한 문장으로 생각하기로 하자. 예를 들어 주어진 문자열 S가 'IamInevitable.IamIronMan.'이라면 'IamInevitable.'이 한 문장, 'IamIronMan.'이 한 문장이다.

규칙은 다음과 같다.

 

  1.  S의 길이가 25 이하면 S를 그대로 출력한다.
  2.  S의 길이가 25 초과이면, S의 앞에서부터 11글자, 뒤에서부터 11글자를 제외하고 나머지 부분을 생각하자. 이 나머지 부분이 모두 같은 문장에 속한다면, 생략한 뒤 '...'('.' 3개)으로 바꿔서 출력한다.
  3. 위 두 경우에 해당되지 않는다면 S를 앞에서부터 9글자, 뒤에서부터 10글자만 남기고 중간은 '......'('.' 6개)으로 바꿔서 출력한다.

 

 

 


  • 풀이 :

문자열 문제입니다.

 

주어진 문자열의 길이가 25 이하라면 그냥 출력하고

아니라면 두 가지 경우로 나눕니다.

 

1. 앞에서 11, 뒤에 11글자를 뺀 가운데 사이가 2 문장 이상을 포함한 경우  앞에서 9, 뒤에서 10글자를 자른 후 사이에 "."을 6개 찍어 출력합니다.

 

2. 반대의 경우 앞에서 11, 뒤에서 11글자를 자른 후 사이에 "."을 3개 넣어 출력합니다.

 

 

 


  • 소스코드 : 
import sys
input = sys.stdin.readline


if __name__ == "__main__":
    N = int(input())
    S = input().strip()
    if N <= 25:
        print(S)
    elif N > 25:
        if "." in S[11:-12]:
            print(S[:9] + "......" + S[-10:])
        else:
            print(S[:11] + "..." + S[-11:])
320x100
댓글
© 2022 WonSeok, All rights reserved