728x90
문제
https://school.programmers.co.kr/learn/courses/30/lessons/12926
문자에 n만큼 더하여 만든 암호 리턴
ord() 와 chr()을 사용
chr(정수) -> 아스키코드 문자로 바꿔줌
ord(문자) -> 아스키코드 숫자로 바꿔줌
ord('a') #97
ord('z') #122
ord('A') #65
ord('Z') #90
#26개가 있음
소문자, 대문자, 공백을 나눠서 생각
if, elif, else로 나눔
알파벳은 총 26개라는 것을 이용
def solution(s, n):
answer = ''
for i in s:
sol = ord(i) + n
#소문자일 때
if "a" <= i <= "z":
#소문자인데 z 넘어갈 때
if sol > ord("z"):
answer += chr(sol - 26)
else:
answer += chr(sol)
#대문자일 때
elif "A" <= i <= "Z":
#대문자인데 Z 넘어갈 때
if sol > ord("Z"):
answer += chr(sol - 26)
else:
answer += chr(sol)
#공백일 때
else:
answer += ' '
return answer
심화 문제
2024.01.10 - [프로그래머스 코딩테스트 문제] - [프로그래머스/Python] 둘만의 암호
'코딩테스트 문제' 카테고리의 다른 글
[프로그래머스/Python] 카드 뭉치 (1) | 2024.01.11 |
---|---|
[프로그래머스/Python] 숫자 짝궁 (0) | 2024.01.11 |
[프로그래머스/Python] 신고 결과 받기 (0) | 2024.01.11 |
[프로그래머스/Python] 둘만의 암호 (0) | 2024.01.10 |
[프로그래머스/Python] 문자열 밀기 (0) | 2024.01.05 |