재귀호출함수 실제로 많이 쓰이나요 *.*

toy의 이미지

C책에보면 단골이 재귀호출인데요.
이거 실전에서 많이 쓰이나요?
메모리도 많이 잡아먹고 안좋을거 같은데..... :oops:

sozu의 이미지

간단한 예로 Depth First Search 를 하는데

Recursive Call 로 짜면 매우 간단하게 짤수 있습니다.

하지만 Iterative Version 으로 짜게 된다면 다소 코드가 길어지며

복잡해 질수 있습니다.

물론 Depth가 일정수 이상 되면 Iterative Version 이 훨씬 빠른 속도를 냅니다.

하지만 그 이하의 Depth 를 보장 받는 다면 궂이 Iterative 하게 짤 필요가 없는것이죠.

제가 예전에 DFS 를 짜놓은것이 있네요. 참고하시라고;;

Recursive Version
http://sozu.pe.kr/moniwiki/wiki.php/DepthFirstSearchForGraph

Iterative Version
http://sozu.pe.kr/moniwiki/wiki.php/DepthFirstSearch-IterativeVersion

-----------
청하가 제안하는 소프트웨어 엔지니어로써 재미있게 사는 법
http://sozu.tistory.com

vacancy의 이미지

제 개인적으로는

직관적으로 구현할 수 있는 경우가 많아서

쓸 수 있는 상황에선 굳이 피하지 않고 씁니다. -_-a

ssehoony의 이미지

어디까지나 알고리즘 복잡도가 중요한게 아닐까요?

재귀호출로 구현한게 간단하다면 그걸로 하는거고 없이 하는게 간단하면 없이 하는거지 꼭 재귀호출을 써야 하거나 아니거나 하는건 아니라고 생각합니다.

물론, 타입 크리티컬한 부분이라면 알고리즘 복잡도 보다는 포퍼먼스 우선으로 하겠지만요.

퀵소팅 같은 경우 재귀호출이 알고리즘 복잡도를 낮춰주니깐 기본적으로 재귀호출하는 방식으로 구현하지만 함수콜의 시스템 부하때문에 재귀호출을 제거하는 방식을 이용하는 경우도 있고요.

voider의 이미지

쓰면 삶이 편해집니다
하지만 맘놓구 쓸순 없습니다
스택 오버플로우, 성능 등등

아직 익숙해지지 않아서 어렵게 느껴지는겁니다
익숙해지면 마구 쓰고싶은 유혹이 ㅡㅡ;;

-- 아쉬운 하루 되세요 --

yielding의 이미지

실전에서도 재귀를 많이 씁니다. 걱정하지 마시고 마음껏 쓰세요.

"Iteration is humane, recursion is divine"
- The C++ programming language에서

Life rushes on, we are distracted

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.