배열만들기 5
문제설명
문자열 배열 intStrs와 정수 k, s, l가 주어집니다. intStrs의 원소는 숫자로 이루어져 있습니다.
배열 intStrs의 각 원소마다 s번 인덱스에서 시작하는 길이 l짜리 부분 문자열을 잘라내 정수로 변환합니다. 이때 변환한 정수값이 k보다 큰 값들을 담은 배열을 return 하는 solution 함수를 완성해 주세요.
접근방법
- 1단계: 배열돌면서 s~l 까지 잘라내기
- 2단계: 크기비교하기(이때 문자열이면 int 형과 비교가 불가능하니까 int로 바꿔줌)
- 3단계: 크면 배열에 추가
def solution(intStrs, k, s, l):
answer = []
for number in intStrs:
part_number = number[s:s+l]
part_number_int = int(part_number)
if part_number_int > k:
answer.append(part_number_int)
return answer
부분문자열 이어붙어 문자열 만들기
문제설명
길이가 같은 문자열 배열 my_strings와 이차원 정수 배열 parts가 매개변수로 주어집니다. parts[i]는 [s, e] 형태로, my_string[i]의 인덱스 s부터 인덱스 e까지의 부분 문자열을 의미합니다. 각 my_strings의 원소의 parts에 해당하는 부분 문자열을 순서대로 이어 붙인 문자열을 return 하는 solution 함수를 작성해 주세요.
접근방법
- parts 정하기= s부터 e까지의 부분 문자열을 추출
- 추출한 부분 문자열을 순서대로 이어붙임
첫번째시도
def solution(my_strings, parts):
answer =""
for word in range(len(my_strings)):
s, e = parts[word]
words = my_strings[word][s:e+1]
answer.append(words)
return answer
🤔 append 를 못쓰는이유?
문자열은 불변 (immutable) 객체이다. 즉, 한 번 생성된 문자열은 변경될 수 없다.
따라서 문자열에 += 연산자를 사용하면 실제로 새로운 문자열이 생성되는 것이다.
리스트는 가변 (mutable) 객체이다.
append는 리스트에 요소를 추가할 때 사용한다.
🤔 가변객체와 불변객체가 뭔데?
가변객체(Mutable Object):
-가변객체는 생성된 후에도 그 내용을 변경할 수 있는 객체를 의미한다.
-리스트(List), 딕셔너리(dictionary), 집합(set) 등이 있다.
불변객체 (immutable Object):
-불변객체는 생성된 후에는 그 내용을 변경할 수 없는 객체를 의미한다.
-문자열(str), 튜플(tuple), 정수(int) 등이 있다.
최종 제출
def solution(my_strings, parts):
answer =""
for word in range(len(my_strings)):
s, e = parts[word]
words = my_strings[word][s:e+1]
answer+=words
return answer
문자열 뒤의 n글자
문제설명
문자열 my_string과 정수 n이 매개변수로 주어질 때, my_string의 뒤의 n글자로 이루어진 문자열을 return 하는 solution 함수를 작성해 주세요.
def solution(my_string, n):
return my_string[-n:]
접미사 배열
문제설명
어떤 문자열에 대해서 접미사는 특정 인덱스부터 시작하는 문자열을 의미합니다. 예를 들어, "banana"의 모든 접미사는 "banana", "anana", "nana", "ana", "na", "a"입니다.
문자열 my_string이 매개변수로 주어질 때, my_string의 모든 접미사를 사전순으로 정렬한 문자열 배열을 return 하는 solution 함수를 작성해 주세요.
접근방법
- 각 인덱스에 접근
- 하나씩 늘려가면서 ~..~ => 인덱스를 하나씩 넣으면 되는거임
- 정렬
해결코드
def solution(my_string):
answer=[]
for word in range(len(my_string)): #각인덱스에접근함
answer.append(my_string[word:])
answer.sort()
return answer
접미사인지 확인하기
문제설명
어떤 문자열에 대해서 접미사는 특정 인덱스부터 시작하는 문자열을 의미합니다. 예를 들어, "banana"의 모든 접미사는 "banana", "anana", "nana", "ana", "na", "a"입니다.
문자열 my_string과 is_suffix가 주어질 때, is_suffix가 my_string의 접미사라면 1을, 아니면 0을 return 하는 solution 함수를 작성해 주세요.
접근방법
- is_suffix 의 길이 확인하기
- my_string 의 끝에서 is_suffix 의 길이만큼 잘라낸다
- 잘라낸 부분 문자열이 is_suffix의 길이와 같은지 확인한다.
- 맞으면 1 아니면 0 반환
def solution(my_string, is_suffix):
# is_suffix의 길이
suffix_length = len(is_suffix)
# my_string의 끝에서 is_suffix의 길이만큼 잘라낸 부분이 is_suffix와 같은지 확인
if is_suffix in my_string[-suffix_length:]:
return 1
else:
return 0
다른 사람코드
def solution(my_string, is_suffix):
if my_string.endswith(is_suffix):
return 1
else:
return 0
endswith() 란?
문자열이 특정 접미사로 끝나는지 확인하는 데 사용
string.endswith(suffix[, start[, end]])
- string: 검사할 문자열.
- suffix: 문자열이 이 값으로 끝나는지 확인할 접미사. 문자열 또는 튜플일 수 있다.
- start: (선택적) 검사할 시작 위치. 기본값은 0
- end: (선택적) 검사할 끝 위치. 기본값은 문자열의 끝
이 메서드는 문자열이 지정된 접미사로 끝나면 True, 그렇지 않으면 False를 반환
'Algorithm' 카테고리의 다른 글
[Python] 프로그래머스 트레이닝 챌린지 D10 (0) | 2024.08.01 |
---|---|
[Python] 프로그래머스 트레이닝 챌린지 D8 (8) | 2024.07.24 |
[Python] 프로그래머스 트레이닝 챌린지 D7 (2) | 2024.07.23 |
[Python] 프로그래머스 트레이닝 챌린지 D6 (7) | 2024.07.22 |
[Python] 프로그래머스 트레이닝 챌린지 D5 (0) | 2024.07.21 |