Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 자연어처리
- AI 경진대회
- 백준
- github
- PYTHON
- SW Expert Academy
- 맥북
- gs25
- Baekjoon
- 금융문자분석경진대회
- 캐치카페
- leetcode
- 프로그래머스
- 편스토랑
- Docker
- 더현대서울 맛집
- 코로나19
- 프로그래머스 파이썬
- Git
- 우분투
- ubuntu
- programmers
- 편스토랑 우승상품
- ChatGPT
- Real or Not? NLP with Disaster Tweets
- hackerrank
- 데이콘
- Kaggle
- dacon
- 파이썬
Archives
- Today
- Total
솜씨좋은장씨
[BaekJoon] 12871번 : 무한 문자열 (Python) 본문
728x90
반응형
코딩 1일 1문제! 오늘의 문제는 백준의 무한 문자열 입니다.
Solution
import math
def get_least_common_multiple(string_s_len, string_t_len):
return string_s_len * string_t_len // math.gcd(string_s_len, string_t_len)
def infinity_string(string_s, string_t):
is_infinity_string = 0
string_s_len = len(string_s)
string_t_len = len(string_t)
standard_len = get_least_common_multiple(string_s_len, string_t_len)
s_multiply_num = standard_len // string_s_len
t_multiply_num = standard_len // string_t_len
if string_s * s_multiply_num == string_t * t_multiply_num:
is_infinity_string = 1
return is_infinity_string
if __name__ == "__main__":
string_s = input()
string_t = input()
print(infinity_string(string_s, string_t))
Solution 풀이
이 문제는 문자열 s와 문자열 t를 각각 무한대로 이어붙였을때
그 무한으로 이어붙인 값이 같은지 다른지를 확인하는 문제입니다.
무한으로 이어붙이고 확인하려면 끝나지않는 연산이기에
맨 처음 같아지는 지점을 찾아야합니다.
바로 그 지점이 두 문자열의 길이의 최소공배수 입니다.
두 문자열을 입력받으면 각 문자열의 길이를 구한 다음
두 문자열 길이의 최소공배수 = 문자열 s의 길이 X 문자열 t의 길이 // 문자열 s의 길이와 문자열 t의 길이의 최대공약수
위의 공식대로 값을 구합니다.
그리고 각 문자열을 얼마나 반복해야하는지 각각 값을 구한다음
해당 횟수만큼 반복한 문자열끼리 비교하여 같으면 1 다르면 0을 출력하도록 하면 끝!
'Programming > 코딩 1일 1문제' 카테고리의 다른 글
[BaekJoon] 4949번 : 균형잡힌 세상 (Python) (0) | 2021.07.16 |
---|---|
[BaekJoon] 1871번 : 좋은 자동차 번호판 (Python) (0) | 2021.07.15 |
[BaekJoon] 20291번 : 파일 정리 (Python) (0) | 2021.07.13 |
[BaekJoon] 7600번 : 문자가 몇갤까 (Python) (0) | 2021.07.12 |
[BaekJoon] 11091번 : 알파벳 전부 쓰기 (Python) (0) | 2021.07.11 |
Comments