C언어 파일입력에 관해서

changlee의 이미지

텍스트 문서를 이진 트리로 받아야 하는데요
fopen, fscanf를 사용 하면되는데

(A,(B,_,_),(C,_,_))
이문서를 받으면

A
/ |
B C

(A,(B,(D,_,_),(E,_,_)),(C,(F,_,_),(G,_,_)))

A
B C
D E F G

이렇게 트리가 생성하려고 하는데
어떻게 받아야 좋을까요?

newyorker의 이미지

void f(Node* n, char* inp)
{
...
n->data = *(inp + 1);
...
// left node
if ( '_' != *(inp + 4) )
{
Node left = (Node*) malloc(sizeof(Node));
n->left = left;
f(n->left, inp + 3);
}
...
// right node
...
}

대강은 이런 식으로요? 함수를 어떤 식으로 만들지 이미 계획하셨다면... 죄송! -_-a

changlee의 이미지

제가 c를 잘 못해서요 ㅠ
좀더 자세한코드랑 성명가능하신가요 ㅠ

raymundo의 이미지

newyorker님의 리플을 해석해 드리면...

    (A,(B,_,_),(C,_,_))
    ^
    inp 여기서부터 읽기 시작
 
    (A,(B,_,_),(C,_,_))
     ^
     inp+1 여기가 데이타 자리
 
    (A,(B,_,_),(C,_,_))
       ^
       inp+3 여기가 왼쪽 하위 노드 자리 (inp+4 라고 쓰신 건 오류겠네요)
       그런데 이 시점에서 보면 (B,...) 이건 또 하위노드를 가질 수 있는 중첩된 형태니까
       여기를 시작으로 해서 다시 재귀호출
 
    ...

뭐 이런 얘기입니다.

좋은 하루 되세요!

댓글 달기

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 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.