김호쭈
DevForYou
김호쭈
전체 방문자
오늘
어제
  • 분류 전체보기 (321)
    • • 데이터베이스(DB) (9)
      • __SQL__ (9)
    • •알고리즘(Algorithm ) (117)
      • 문제풀이 (99)
      • 스터디 (14)
      • 알고리즘 팁 (4)
    • •Compter Science (57)
      • Operating System (25)
      • Computer Network (1)
      • Computer Vision (16)
      • Artificial Intelligence (14)
      • Software Technology (1)
    • • 독서 (36)
      • Design Pattern (24)
      • 객체지향의 사실과 오해 (1)
      • Object Oriented Software En.. (11)
    • • 개발 (26)
      • React (3)
      • node.js (6)
      • Django (11)
      • Spring boot (6)
    • • 개발Tip (4)
      • GitHub (0)
    • •프로젝트 (2)
      • 물물 (2)
    • •App (54)
      • 안드로이드 with Kotlin (50)
      • 코틀린(Kotiln) (4)
    • •회고 (8)
    • •취준일기 (3)
    • • 기타 (2)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • local저장소
  • Remote저장소
  • ㄱ
  • GitHubDesktop
  • 로컬저장소
  • 깃허브데스크탑
  • 원격저장소
  • KMU_WINK

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
김호쭈

DevForYou

•알고리즘(Algorithm )/스터디

[알고리즘] 재귀함수 파이썬, 회문검사

2022. 7. 23. 22:36

# 내용

재귀함수를 이용하여 회문검사, 파이썬 스트링 다루기 공부

파이썬에서는 재귀는 1000번까지만 호출 가능함

재귀 함수의 잦은 사용을 막기 위해 동적 계획법(Dynamic Programming)을 이용 할 수 있음.

동적 계획법은 앞서 사용했던 것들을 이용하여 그다음 문제를 풀때 사용하는 것. 

 

# 코드

import random

def sum_list(data):
  sum = 0
  for i in data:
    sum += i
  return sum

def reculsive_sum(data):
  if len(data) == 1:
    return data[0]
  return data[0] + reculsive_sum(data[1:])

# 회문 검사
def palindrome(str):
  for index in range( len(str) // 2 ):
    if (str[index] != str[-(index+1)]):
      return False
  return True

# 재귀 회문 검사
def reculsive_palindrome(str):
  if len(str) <= 1:
    return True
  else:
    if(str[0] == str[-1]):
      return reculsive_palindrome(str[1:-1])
    else:
      return False

if __name__ == '__main__':
    str = "level123"
    print(palindrome(str))
    print(reculsive_palindrome(str))

 

저작자표시 (새창열림)

'•알고리즘(Algorithm ) > 스터디' 카테고리의 다른 글

[알고리즘] 이진탐색 파이썬 및 시간복잡도  (0) 2022.07.26
[알고리즘] 병합정렬(merge-sort) 파이썬  (0) 2022.07.24
[알고리즘] 선택 정렬 파이썬  (0) 2022.07.22
[알고리즘] 삽입정렬 파이썬  (0) 2022.07.22
[알고리즘] 버블정렬 파이썬  (0) 2022.07.22
    '•알고리즘(Algorithm )/스터디' 카테고리의 다른 글
    • [알고리즘] 이진탐색 파이썬 및 시간복잡도
    • [알고리즘] 병합정렬(merge-sort) 파이썬
    • [알고리즘] 선택 정렬 파이썬
    • [알고리즘] 삽입정렬 파이썬
    김호쭈
    김호쭈
    공부하고 정리하고 기록하기

    티스토리툴바