Leta Learns

[모각코] 220723 Today I Learned 본문

HUFS/HUFS 모각코 캠프

[모각코] 220723 Today I Learned

leta 2022. 7. 23. 13:11

 

<백준 1259번 - 팰린드롬수>

 

예전에 팰린드롬 문제로 실버 난이도를 풀은 적 있는 것 같다.

난이도가 달라서 그런지는 몰라도 일단 쉽게 풀었다.

근데 좀 더 간단한 코드로 짤 수 있는 방법이 있을 것 같은 느낌..

import sys
input = sys.stdin.readline

num = []
a = 1
while a != '0':
    a = input().strip()
    num.append(a)

for i in num:
    pal = 1
    if i == '0':
        break
    if len(i) % 2 == 0: #짝수
        for j in range(len(i)):
            if i[j] != i[len(i)-j-1]:
                pal = 0
                break
            if j == len(i) // 2:
                break
    else:
        for j in range(len(i)):
            if i[j] != i[len(i)-j-1]:
                pal = 0
                break
            if j > len(i)//2:
                break
            
    if pal == 0:
        print("no")
    elif pal == 1:
        print("yes")

 

 

 

<백준 1436번 - 영화감독 숌>

 

브론즈 한 개 푼 게 양심에 찔려서 한 문제 더 풀었다.

 

처음에 어떻게 풀어야 할 지 감이 잘 안 잡혔는데, 너무 어렵게 생각해서 그랬던 것 같다.

그냥 수를 1씩 키워가면서 그 안에 666이 들어가는 경우를 찾으면 된다.

 

import sys
input = sys.stdin.readline

n = int(input())

ans = '666'
cnt = 1
while cnt != n:
    intans = int(ans)
    intans += 1
    ans = str(intans)
    if '666' in ans:
        cnt += 1
print(ans)

 

 

Comments