Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 1차원 DP
- 2차원 dp
- 99클럽
- @Builder
- @Entity
- @GeneratedValue
- @GenericGenerator
- @NoargsConstructor
- @Query
- @Table
- @Transactional
- Actions
- Amazon EFS
- amazon fsx
- Android Studio
- ANSI SQL
- ApplicationEvent
- assertThat
- async/await
- AVG
- AWS
- Azure
- bind
- builder
- button
- c++
- c++ builder
- c03
- Callback
- case when
Archives
- Today
- Total
기록
백준_9935_문자열 폭발 본문
문제
풀이
- 입력 문자열 w를 배열 ans에 넣는다.
- 마지막으로 넣은 문자가 패턴 p의 마지막 문자와 같고 ans의 크기가 p의 크기보다 크다면
- 패턴 p의 마지막 문자부터 ans를 검사한다.
- 검사 결과가 true일때 패턴 p의 길이만큼 ans.pop()
ans에 저장된 문자들을 join연산으로 붙여서 프린트한다. ans의 크기가 p의 크기를 비교하는 조건이 없으면, 뒤에서부터 문자열을 검사하는 코드에서 ans의 길이가 p보다 작을때 인덱스를 벗어나는 에러가 발생한다.
코드
w = input()
p = input()
ans = list()
for i in range(len(w)) :
ans.append(w[i])
# ans의 마지막 값과 p의 마지막 값이 같으면
if ans[-1]==p[-1] and len(ans)>=len(p):
check = True
# 뒤에서 부터 검사
for k in range(1, len(p)+1) :
if ans[-k] != p[-k] :
check = False #하나라도 다르면 false
break
# 검사 결과가 true일때 p 길이만큼 pop
if check :
for k in range(len(p)) :
ans.pop()
ans = "".join(ans)
if ans=="" : print("FRULA")
else : print(ans)
'코딩테스트 > python' 카테고리의 다른 글
백준_1085_직사각형에서 탈출 (0) | 2020.12.28 |
---|---|
백준_1259_팰린드롬수 (0) | 2020.12.28 |
백준_17144_미세먼지 안녕! (0) | 2020.08.29 |
백준_1786_찾기 (0) | 2020.08.29 |
백준_1016_제곱ㄴㄴ수 (0) | 2020.08.28 |
Comments