모바일 오유 바로가기
http://m.todayhumor.co.kr
분류 게시판
베스트
  • 베스트오브베스트
  • 베스트
  • 오늘의베스트
  • 유머
  • 유머자료
  • 유머글
  • 이야기
  • 자유
  • 고민
  • 연애
  • 결혼생활
  • 좋은글
  • 자랑
  • 공포
  • 멘붕
  • 사이다
  • 군대
  • 밀리터리
  • 미스터리
  • 술한잔
  • 오늘있잖아요
  • 투표인증
  • 새해
  • 이슈
  • 시사
  • 시사아카이브
  • 사회면
  • 사건사고
  • 생활
  • 패션
  • 패션착샷
  • 아동패션착샷
  • 뷰티
  • 인테리어
  • DIY
  • 요리
  • 커피&차
  • 육아
  • 법률
  • 동물
  • 지식
  • 취업정보
  • 식물
  • 다이어트
  • 의료
  • 영어
  • 맛집
  • 추천사이트
  • 해외직구
  • 취미
  • 사진
  • 사진강좌
  • 카메라
  • 만화
  • 애니메이션
  • 포니
  • 자전거
  • 자동차
  • 여행
  • 바이크
  • 민물낚시
  • 바다낚시
  • 장난감
  • 그림판
  • 학술
  • 경제
  • 역사
  • 예술
  • 과학
  • 철학
  • 심리학
  • 방송연예
  • 연예
  • 음악
  • 음악찾기
  • 악기
  • 음향기기
  • 영화
  • 다큐멘터리
  • 국내드라마
  • 해외드라마
  • 예능
  • 팟케스트
  • 방송프로그램
  • 무한도전
  • 더지니어스
  • 개그콘서트
  • 런닝맨
  • 나가수
  • 디지털
  • 컴퓨터
  • 프로그래머
  • IT
  • 안티바이러스
  • 애플
  • 안드로이드
  • 스마트폰
  • 윈도우폰
  • 심비안
  • 스포츠
  • 스포츠
  • 축구
  • 야구
  • 농구
  • 바둑
  • 야구팀
  • 삼성
  • 두산
  • NC
  • 넥센
  • 한화
  • SK
  • 기아
  • 롯데
  • LG
  • KT
  • 메이저리그
  • 일본프로야구리그
  • 게임1
  • 플래시게임
  • 게임토론방
  • 엑스박스
  • 플레이스테이션
  • 닌텐도
  • 모바일게임
  • 게임2
  • 던전앤파이터
  • 마비노기
  • 마비노기영웅전
  • 하스스톤
  • 히어로즈오브더스톰
  • gta5
  • 디아블로
  • 디아블로2
  • 피파온라인2
  • 피파온라인3
  • 워크래프트
  • 월드오브워크래프트
  • 밀리언아서
  • 월드오브탱크
  • 블레이드앤소울
  • 검은사막
  • 스타크래프트
  • 스타크래프트2
  • 베틀필드3
  • 마인크래프트
  • 데이즈
  • 문명
  • 서든어택
  • 테라
  • 아이온
  • 심시티5
  • 프리스타일풋볼
  • 스페셜포스
  • 사이퍼즈
  • 도타2
  • 메이플스토리1
  • 메이플스토리2
  • 오버워치
  • 오버워치그룹모집
  • 포켓몬고
  • 파이널판타지14
  • 배틀그라운드
  • 기타
  • 종교
  • 단어장
  • 자료창고
  • 운영
  • 공지사항
  • 오유운영
  • 게시판신청
  • 보류
  • 임시게시판
  • 메르스
  • 세월호
  • 원전사고
  • 2016리오올림픽
  • 2018평창올림픽
  • 코로나19
  • 2020도쿄올림픽
  • 게시판찾기
  • 게시물ID : programmer_9613
    작성자 : 천이랑
    추천 : 0
    조회수 : 6855
    IP : 223.32.***.168
    댓글 : 11개
    등록시간 : 2015/04/29 11:44:13
    http://todayhumor.com/?programmer_9613 모바일
    [C] 자료구조 라인에디터를 만들고 있습니다. 도움 부탁드려요!
    옵션
    • 베스트금지
    • 본인삭제금지
    C언어로 자료구조를 배우고 있습니다.

    배우고 있는 책에 리스트ADT를 이용한 라인 에디터 코드가 있어 이를 단순 연결리스트가 아닌 이중 연결리스트로 구현해 보려고 시도했는데요,

    간단히 insert_node와 add함수만 잠깐 수정해주면 될 줄 알았더니 0번 라인에 입력하니 프로그램이 종료되는 현상이 발생하네요.. 아마 수정한 코드에서 오류가 발생한 것이 아닐까 한데 문제는 이 수정한 코드들도 책 안에 있는 코드를 따온 것이란 겁니다.. 어디가 잘못된건지 감이 안잡히네요 ㅠㅠ

    제가 한 작업은 단순히 ListNode구조체에 link대신 llink와 rlink로 포인터를 부여하였고, insert_node함수를 단순 연결리스트의 함수가 아닌 이중 연결리스트의 삽입 함수로 변경한 것이 다입니다.  디버깅을 해보니 46번째줄 코드에서 에러가 나오네요..

    0번에 입력할때는 프로그램이 종료되고, 1번이나 2번 다른 라인에 입력할때는 오류가 출력되는 대신 아무것도 저장되질 않습니다.. 대체 뭘 수정해야 정상적으로 작동할까요? 도움이 절실합니다!

    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
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    241
    242
    243
    244
    245
    246
    247
    248
    249
    250
    251
    252
    253
    254
    255
    256
    257
    258
    259
    260
    261
    262
    263
    264
    265
    266
    267
    268
    269
    #include <stdio.h>
    #include <stdlib.h>
    #include <ctype.h>
    #include <string.h>
    #include <limits.h>
    #include <malloc.h>
     
     
    #define MAX_CHAR_PER_LINE 1000
    #define MAX_NAME 256
    void warning(char *);
    void error(char *);
     
    #define FALSE 0
    #define TRUE 1
     
    typedef struct{
        char a[MAX_CHAR_PER_LINE];
    } element;
     
    typedef struct ListNode{
        element data;
        struct ListNode *llink;
        struct ListNode *rlink;
    } ListNode;
     
    typedef struct{
        ListNode *head;
        int length;
    } LinkedListType;
     
    void init(LinkedListType *list) // List의 초기화
    {
        if(list==NULL) return;
        list->length=0;
        list->head=NULL;
    }
     
    void insert_node(ListNode *before, ListNode *new_node)
    {
        new_node->llink=before;
        new_node->rlink=before->rlink;
        before->rlink->llink=new_node;
        before->rlink=new_node;
    }
     
    void remove_node(ListNode *phead_node, ListNode *removed)
    {
        if(removed==phead_node) return;
        removed->llink->rlink=removed->rlink;
        removed->rlink->llink=removed->llink;
        free(removed);
    }
     
    ListNode *get_node_at(LinkedListType *list, int pos)
    {
        int i;
        ListNode *tmp_node=list->head;
        if(pos<0return NULL;
        for(i=0;i<pos;i++) tmp_node=tmp_node->rlink;
        return tmp_node;
    }
     
    int get_length(LinkedListType *list){
        return list->length;
    }
     
    void add(LinkedListType *list, int position, element data)
    {
        ListNode *p;
        if((position>=0)&&(position<=list->length)){
            ListNode *node=(ListNode *)malloc(sizeof(ListNode));
            if(node==NULL) error("Memory Allocate ERROR!");
            node->data=data;
            p=get_node_at(list, position-1);
            insert_node(p, node);
            list->length++;
        }
    }
     
    void add_last(LinkedListType *list, element data)
    {
        add(list,get_length(list),data);
    }
     
    void add_first(LinkedListType *list, element data)
    {
        add(list, 0, data);
    }
     
    int is_empty(LinkedListType *list)
    {
        if(list->head==NULL) return 1;
        else return 0;
    }
     
    void delete(LinkedListType *list, int pos)
    {
        if(!is_empty(list)&&(pos>=0)&&(pos<list->length)){
            ListNode *p=get_node_at(list, pos-1);
            remove_node(p,(p!=NULL)?p->rlink:NULL);
            list->length--;
        }
    }
     
    element get_entry(LinkedListType *list, int pos) // 주어진 위치에 해당하는 데이터 반환 
    {
        ListNode *p;
        if(pos>=list->length) error("Pos ERROR!");
        p=get_node_at(list, pos);
        return p->data;
    }
     
    void clear(LinkedListType *list) // 모든 노드를 삭제 
    {
        int i;
        for(i=0;i<list->length;i++)
            delete(list, i);
    }
     
    void display(LinkedListType *buffer) // buffer의 내용 출력 
    {
        int i;
        ListNode *tmp_node;
        tmp_node=buffer->head;
        
        printf("********************\n");
        for(i=0;i<buffer->length;i++){
            printf("%s", tmp_node->data.a);
            tmp_node=tmp_node->rlink;
        }
        printf("********************\n");
    }
     
    void warning(char *message) // 경고 메세지 출력
    {
        fprintf(stderr, "%s\n", message);
    }
     
    void error(char *message) // 에러 메세지 출력
    {
        fprintf(stderr, "%s\n", message);
        exit(1);
    }
     
    void help() // 메뉴 출력
    {
        printf("********************\n");
        printf("i: INSERT\n");
        printf("d: DELETE\n");
        printf("r: READ FILE\n");
        printf("w: WRITE FILE\n");
        printf("q: QUIT\n");
        printf("********************\n");
    }
     
    void read_file(LinkedListType *buffer) // disk file로부터 data를 읽음
    {
        char fname[MAX_NAME];
        FILE *fd;
        element p;
        
        if(!is_empty(buffer)){
            clear(buffer);
        }
        init(buffer);
        
        printf("FILE NAME: ");
        scanf("%s", fname);
        if((fd=fopen(fname,"r"))==NULL){
            warning("Can't open file.\n");
            return;
        }
        while(fgets(p.a, MAX_CHAR_PER_LINE, fd)){
            add_last(buffer, p);
        }
        fclose(fd);
        display(buffer);
    }
     
    void write_file(LinkedListType *buffer) // buffer에 있는 data를 disk file에 씀
    {
        FILE *fd;
        char fname[MAX_NAME];
        element p;
        int i;
        
        printf("FILE NAME: ");
        scanf("%s", fname);
        if((fd=fopen(fname, "w"))==NULL){
            printf("Can't open file.\n");
            return;
        }
        for(i=0;i<get_length(buffer);i++){
            p=get_entry(buffer, i);
            fputs(p.a, fd);
        }
        fclose(fd);
        display(buffer);
    }
     
    void delete_line(LinkedListType *buffer) // 하나의 라인 삭제 
    {
        int position;
        
        if(is_empty(buffer))
            printf("Line is already empty!\n");
        else
        {
            printf("Input line number: ");
            scanf("%d",&position);
            delete(buffer, position);
        }
        display(buffer);
    }
     
    void insert_line(LinkedListType *buffer) // 하나의 라인 삽입
    {
        int position;
        char line[MAX_CHAR_PER_LINE];
        element p;
        
        printf("Input line number: ");
        scanf("%d", &position);
        
        printf("Input: ");
        fflush(stdin);
        fgets(line, MAX_CHAR_PER_LINE, stdin);
        strcpy(p.a, line);
        add(buffer, position, p);
        display(buffer);
    }
     
    void do_command(LinkedListType *buffer, char command) // 커맨드 창 출력
    {
        switch(command)
        {
            case 'd':
                delete_line(buffer);
                break;
            case 'i':
                insert_line(buffer);
                break;
            case 'r':
                read_file(buffer);
                break;
            case 'w':
                write_file(buffer);
                break;
            case 'q':
                break;
        }
    }
     
    int main()
    {
        char command;
        LinkedListType buffer;
        
        init(&buffer);
        do{
            help();
            command=getchar();
            do_command(&buffer, command);
            fflush(stdin);
        } while(command!='q');
        
        return 0;
    }
    cs
    출처 C언어로 쉽게 풀어쓴 자료구조(생능출판)

    이 게시물을 추천한 분들의 목록입니다.
    푸르딩딩:추천수 3이상 댓글은 배경색이 바뀝니다.
    (단,비공감수가 추천수의 1/3 초과시 해당없음)

    죄송합니다. 댓글 작성은 회원만 가능합니다.

    번호 제 목 이름 날짜 조회 추천
    23453
    로또번호 [2] 까망사투리 24/09/19 11:10 798 1
    23452
    AI와 함께가는 코딩 업계 [1] 펌글 우가가 24/09/02 22:19 1129 9
    23451
    Switch문 도배된 2100줄 짜리 함수 [2] 펌글 우가가 24/08/26 22:37 1120 4
    23450
    개인정보 수집 없는 이미지 리사이즈 사라밍 24/08/23 20:31 750 0
    23449
    디자인 패턴의 템플릿 메소드 패턴 실무 적용 사례 써니썬 24/08/23 16:47 793 1
    23448
    TMDB API Key 얻을 때 동의하게 되는 면책 및 포기 조항 우가가 24/08/18 16:07 766 1
    23447
    펌) 아무튼 개쩌는 번역기를 국내기술로 개발완료 했다는 소식 [1] 펌글 우가가 24/08/15 17:30 1018 2
    23446
    쿠팡 가격 변동 추적 알림 서비스 피드백 요청 (제발) 창작글펌글 애오옹 24/08/10 14:30 888 0
    23445
    넥사크로 17.1 관련 [2] 본인삭제금지 나르하나 24/08/01 12:30 1035 0
    23444
    개밯자 의자에 머리받침 없어 [1] 까망사투리 24/07/25 13:32 1287 1
    23443
    안드로이드 EditText 리스너 연동 문의드립니다. - 해결됨 [1] 창작글 상사꽃 24/07/01 17:47 1294 2
    23442
    펌) 파이어폭스 엔진이 신인 이유 [1] 펌글 우가가 24/06/30 23:25 1837 2
    23441
    예전에는 함수 하나에 대한 기능에 고민을 많이 했는데.. ssonacy 24/05/21 09:45 1697 0
    23440
    c++ 에서 DB 쿼리문처럼 사용할 방법이 있을까요? [8] 상사꽃 24/05/19 11:10 1832 0
    23439
    쉬운 배터리 알림 창작글 언젠가아자 24/05/14 10:47 1978 0
    23438
    아후 서터레스 [1] NeoGenius 24/04/02 17:52 1704 1
    23436
    로또 [3] 까망사투리 24/03/11 15:53 2321 4
    23434
    copilot 기업유료버전 intelliJ에 붙여서 쓰고있는데 지리네요 안녕월드 24/02/22 00:15 2343 0
    23433
    코딩마을 대나무숲 [6] cocoa 24/02/20 14:50 2503 5
    23432
    (질문) 프로그래머분들은 싱글PC게임 레벨제한 풀수 있죠?? [23] 본인삭제금지 할배궁디Lv2 24/02/13 13:36 2520 1
    23431
    Freemium NeoGenius 24/02/13 13:23 1993 0
    23429
    부산에서 프로그래머 구인하는데 연봉 6천에서 8천 작은건가 [3] 폴팡 24/02/04 20:50 2805 1
    23427
    chatgpt? bard? [4] 별빛러브 24/01/25 06:24 2140 0
    23426
    Next.js로 만들어봤어요~ [2] 창작글 sonnim 24/01/24 12:52 2340 3
    23425
    Spring Boot 공부하기 - 한국투자증권 오픈API 호출 옐로우황 24/01/21 17:51 2316 1
    23424
    파이썬 코딩 관련해서 질문드립니다. [5] 투투나 24/01/08 09:49 2459 0
    23423
    9년차 개발자의 "나만의 챗봇" 만들기 with ChatGPT [2] 아자뵤옹 23/12/10 22:35 2664 4
    23420
    이 에러가 뭘까요? [2] +.푸른바다.+ 23/11/03 15:25 2794 1
    23419
    [유니티 코리아] MWU 2023 투표하고 푸짐한 경품 받아가세요! engine1 23/10/06 18:52 2337 0
    23418
    Flutter로 만든 채팅 어플리케이션 with ChatGPT 아자뵤옹 23/09/13 22:39 2867 0
    [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [다음10개▶]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈