[코테준비]/[코테준비]Python

[코테준비]프로그래머스 코딩 기초 트레이닝 DAY9 Python <문자열>

bestFinanceDataAnalyist 2023. 8. 24. 17:02

https://school.programmers.co.kr/learn/challenges/training?order=acceptance_desc&languages=python3

프로그래머스 코딩 기초 트레이닝 연습풀이입니다. 모든 문제의 저작권은 프로그래머스에게 있으며 문제가 됐을 시 삭제하겠습니다.

 


 

DAY9 문자열

배열만들기5

문제설명

문자열 배열 intStrs와 정수 k, s, l가 주어집니다. intStrs의 원소는 숫자로 이루어져 있습니다.

배열 intStrs의 각 원소마다 s번 인덱스에서 시작하는 길이 l짜리 부분 문자열을 잘라내 정수로 변환합니다. 이때 변환한 정수값이 k보다 큰 값들을 담은 배열을 return 하는 solution 함수를 완성해 주세요

 

 

intStrs                                                                                                                  k              s           l       result

["0123456789","9876543210","9999999999999"] 50000 5 5 [56789, 99999]

슈도코드

기존과 했던 것처럼 동일하게 빈 배열 만들고, 문자열 자른것과 k와 비교해서 빈 배열에 추가한다.

 

전체코드

def solution(intStrs, k, s, l):
    answer = []
    for string in intStrs:
        substring = string[s:s+l]
        num = int(substring)
        if num > k:
            answer.append(num)
    return answer

 

 

 

 

 

부분문자열이어붙여문자열만들기

문제설명

길이가 같은 문자열 배열 my_strings와 이차원 정수 배열 parts가 매개변수로 주어집니다. parts[i]는 [s, e] 형태로, my_string[i]의 인덱스 s부터 인덱스 e까지의 부분 문자열을 의미합니다. 각 my_strings의 원소의 parts에 해당하는 부분 문자열을 순서대로 이어 붙인 문자열을 return 하는 solution 함수를 작성해 주세요.

 

슈도코드

위의 배열만들기 와 동일하게 s~e까지 모아논 문자열 빼놓고 배열 뒤집기 하기

 

전체코드

def solution(my_strings, parts):
    sub = my_strings[s:e+1]
    rev = sub[::-1]
    return rev

 

 

 

 

문자열뒤의n글자

문제설명

문자열 my_string과 정수 n이 매개변수로 주어질 때, my_string의 뒤의 n글자로 이루어진 문자열을 return 하는 solution 함수를 작성해 주세요.

 

my_string                                                                              n                               result

"ProgrammerS123" 11 "grammerS123"
"He110W0r1d" 5 "W0r1d"

슈도코드

아무생각없이 처음에 [n:] 했는데 뒤에서부터 세는거니까 -n으로 해야 그만큼의 글자가 나오는 걸 깨달았다..

 

전체코드

def solution(my_string, n):
    answer = my_string[-n:]
    return answer

 

 

 

 

접미사배열

문제설명

어떤 문자열에 대해서 접미사는 특정 인덱스부터 시작하는 문자열을 의미합니다. 예를 들어, "banana"의 모든 접미사는 "banana", "anana", "nana", "ana", "na", "a"입니다.
문자열 my_string이 매개변수로 주어질 때, my_string의 모든 접미사를 사전순으로 정렬한 문자열 배열을 return 하는 solution 함수를 작성해 주세요.

 

슈도코드

길이만큼 반복문 돌리기... for i in length(  ) 해놓고 빈 배열에 추가할 때 [i:] 하기

 

전체코드

def solution(my_string):
    answer = []
    for i in range(len(my_string)):
        answer.append(my_string[i:])
    return sorted(answer)

 

 

접미사인지확인하기

문제설명

어떤 문자열에 대해서 접미사는 특정 인덱스부터 시작하는 문자열을 의미합니다. 예를 들어, "banana"의 모든 접미사는 "banana", "anana", "nana", "ana", "na", "a"입니다. 문자열 my_string과 is_suffix가 주어질 때, is_suffix가 my_string의 접미사라면 1을, 아니면 0을 return 하는 solution 함수를 작성해 주세요.

 

슈도코드

위에 푼 문제에서 비교 하는 함수 하나 더만들기

 

전체코드

def solution(my_string, is_suffix):
    answer = []
    for i in range(len(my_string)):
        answer.append(my_string[i:])
 
    if is_suffix in answer:
        return 1
    else:
        return 0