<4D F736F F F696E74202D20C1A63137C0E520B5BFC0FBB8DEB8F0B8AEBFCD20BFACB0E1B8AEBDBAC6AE>

Similar documents
11장 포인터

이번장에서학습할내용 동적메모리란? malloc() 와 calloc() 연결리스트 파일을이용하면보다많은데이터를유용하고지속적으로사용및관리할수있습니다. 2

Microsoft PowerPoint - ch09 - 연결형리스트, Stack, Queue와 응용 pm0100

슬라이드 1

Microsoft PowerPoint - Chapter14_17.pptx

Microsoft PowerPoint - Lesson14.pptx

Microsoft PowerPoint - Lesson14.pptx

<4D F736F F F696E74202D20C1A63132B0AD20B5BFC0FB20B8DEB8F0B8AEC7D2B4E7>


PowerPoint 프레젠테이션

PowerPoint Template

Microsoft PowerPoint - chap11-포인터의활용.pptx

슬라이드 1

<322EBCF8C8AF28BFACBDC0B9AEC1A6292E687770>

A Hierarchical Approach to Interactive Motion Editing for Human-like Figures

Lab 3. 실습문제 (Single linked list)_해답.hwp

Lab 4. 실습문제 (Circular singly linked list)_해답.hwp

슬라이드 1

C 언어 강의노트

chap 5: Trees

원형연결리스트에대한설명중틀린것은 모든노드들이연결되어있다 마지막에삽입하기가간단한다 헤더노드를가질수있다 최종노드포인터가 NULL이다 리스트의 번째요소를가장빠르게찾을수있는구현방법은무엇인가 배열 단순연결리스트 원형연결리스트 이중연결리스트 단순연결리스트의노드포인터 가마지막노드를

11장 포인터

Microsoft PowerPoint - ch07 - 포인터 pm0415

A Dynamic Grid Services Deployment Mechanism for On-Demand Resource Provisioning

Microsoft PowerPoint - 제11장 포인터(강의)

Microsoft PowerPoint - 제11장 포인터

untitled

Chapter 4. LISTS

금오공대 컴퓨터공학전공 강의자료

Microsoft PowerPoint - chap13-입출력라이브러리.pptx

슬라이드 1

untitled

03_queue

Chapter 4. LISTS

제 14 장포인터활용 유준범 (JUNBEOM YOO) Ver 본강의자료는생능출판사의 PPT 강의자료 를기반으로제작되었습니다.

untitled

06장.리스트

1 장 C 언어복습 표준입출력배열포인터배열과포인터함수 const와포인터구조체컴파일러사용방법 C++ 프로그래밍입문

윤성우의 열혈 TCP/IP 소켓 프로그래밍

학습목차 2.1 다차원배열이란 차원배열의주소와값의참조

Microsoft PowerPoint - 05-chap03-ArrayAndPointer.ppt

Infinity(∞) Strategy

PowerPoint 프레젠테이션

Microsoft PowerPoint - chap06-2pointer.ppt

Microsoft PowerPoint - chap-11.pptx

Microsoft PowerPoint - 자료구조2008Chap06

PowerPoint 프레젠테이션

Algorithms

PowerPoint 프레젠테이션

리스트 (list), 선형리스트 (linear list): 순서를가진항목들의모임 집합 : 항목간의순서의개념이없음 L = n ( item0, item1,..., item -1) l 리스트의예 l 요일 : ( 일요일, 월요일,, 토요일 ) l 한글자음의모임 : ( ㄱ, ㄴ

1장. 리스트

Microsoft PowerPoint - chap10-함수의활용.pptx

본 강의에 들어가기 전

<4D F736F F F696E74202D20C1A637C0E52DB0EDB1DEBFACB0E1B8AEBDBAC6AE2E >

Microsoft PowerPoint - ch08 - 구조체 (structure) am0845

Chapter 4. LISTS

제 11 장포인터 유준범 (JUNBEOM YOO) Ver 본강의자료는생능출판사의 PPT 강의자료 를기반으로제작되었습니다.

Microsoft PowerPoint - ch10 - 이진트리, AVL 트리, 트리 응용 pm0600

<4D F736F F F696E74202D20B8AEB4AABDBA20BFC0B7F920C3B3B8AEC7CFB1E22E BC8A3C8AF20B8F0B5E55D>

Lab 5. 실습문제 (Double linked list)-1_해답.hwp

Microsoft PowerPoint - chap02-C프로그램시작하기.pptx

기초컴퓨터프로그래밍


슬라이드 1

Contents v 학습목표 자료구조큐에대한개념을스택과비교하여이해한다. 큐의특징과연산방법에대해알아본다. 순차표현방법을이용한큐와연결표현방법을이용한큐를구현해본다. 큐의응용방법을알아본다. v 내용 큐 큐의구현 큐의응용 2/74

슬라이드 1

구조체정의 자료형 (data types) 기본자료형 (primitive data types) : char, int, float 등과같이 C 언어에서제공하는자료형. 사용자정의자료형 (user-defined data types) : 다양한자료형을묶어서목적에따라새로운자료형을

<4D F736F F F696E74202D FBFACB0E120C0DAB7E1B1B8C1B6205BC8A3C8AF20B8F0B5E55D>

PowerPoint 프레젠테이션

중간고사 (자료 구조)

Microsoft PowerPoint - Chapter8.pptx

1장. 유닉스 시스템 프로그래밍 개요

설계란 무엇인가?

02장.배열과 클래스

CHAP 3:배열, 구조체, 포인터

0. 표지에이름과학번을적으시오. (6) 1. 변수 x, y 가 integer type 이라가정하고다음빈칸에 x 와 y 의계산결과값을적으시오. (5) x = (3 + 7) * 6; x = 60 x = (12 + 6) / 2 * 3; x = 27 x = 3 * (8 / 4

Microsoft PowerPoint - 09_C_Language_Pointer_Advanced

C 프로그래밊 개요

슬라이드 1

4장

[ 마이크로프로세서 1] 2 주차 3 차시. 포인터와구조체 2 주차 3 차시포인터와구조체 학습목표 1. C 언어에서가장어려운포인터와구조체를설명할수있다. 2. Call By Value 와 Call By Reference 를구분할수있다. 학습내용 1 : 함수 (Functi

슬라이드 1

Microsoft PowerPoint - 06-Pointer and Memory.pptx

BMP 파일 처리

1. 리스트개념 리스트 (list) 고정된길이의자료 ( 원소 ) 들을순차적으로나열해놓은집합을가르키는자료구조의추상적인개념 순서를가진항목들의모임 집합 (set) : 항목간의순서의개념이없음 리스트의예 요일 : ( 일요일, 월요일,, 토요일 ) 한글자음의모임 : (ᄀ,ᄂ,,ᄒ

리스트구현방법 배열 (array) 을이용하는방법 구현이간단 삽입, 삭제동작에따른원소이동. 항목의개수제한, 정적기억공간할당. 메모리낭비, 오버플로우 연결리스트 (linked list) 를이용하는방법 구현이복잡 삽입, 삭제가효율적 크기가제한되지않음 Lecture 03_Li

Microsoft PowerPoint - chap4_list

KNK_C_05_Pointers_Arrays_structures_summary_v02

3. 1 포인터란 3. 2 포인터변수의선언과사용 3. 3 다차원포인터변수의선언과사용 3. 4 주소의가감산 3. 5 함수포인터

목차 포인터의개요 배열과포인터 포인터의구조 실무응용예제 C 2

슬라이드 1

슬라이드 1

Microsoft PowerPoint - 제3장-배열.pptx

Microsoft PowerPoint - chap06-1Array.ppt

슬라이드 1

슬라이드 1

PowerPoint 프레젠테이션

ch15

리스트연산, 검색 + 삽입 + 삭제 새로운항목을리스트의처음, 중간, 끝에추가. 기존의항목을리스트의임의의위치에서삭제. 모든항목을삭제. 기존항목을대치 (replace). 리스트가특정항목을가지고있는지를검색 (search). 리스트의특정위치의항목을반환. 리스트안의항목의개수를센

PowerPoint 프레젠테이션

Transcription:

쉽게풀어쓴 C 언어 Express 제 17 장동적메모리와연결리스트

이번장에서학습할내용 동적메모리할당의이해 동적메모리할당관련함수 연결리스트 동적메모리할당에대한개념을이해하고응용으로연결리스트를학습합니다.

동적할당메모리의개념 프로그램이메모리를할당받는방법 정적 (static) 동적 (dynamic)

정적메모리할당 정적메모리할당 프로그램이시작되기전에미리정해진크기의메모리를할당받는것 메모리의크기는프로그램이시작하기전에결정 ( 예 ) int score_s[100]; 처음에결정된크기보다더큰입력이들어온다면처리하지못함 더작은입력이들어온다면남은메모리공간은낭비

동적메모리할당 동적메모리할당 실행도중에동적으로메모리를할당받는것 사용이끝나면시스템에메모리를반납 score = (int *) malloc(100*sizeof(int)); 필요한만큼만할당을받고메모리를매우효율적으로사용 malloc() 계열의라이브러리함수를사용 운영체제 할당요구 #include #include <stdio.h> <stdio.h> #include #include <stdlib.h> <stdlib.h> int int main(void) main(void) { int int *p; *p; p = (int (int *)malloc( *)malloc( sizeof(int) sizeof(int) ); );...... } 프로그램

동적메모리할당절차

동적메모리할당예제 #include <stdio.h> #include <stdlib.h> int main(void) { int *score; int i; score = (int *)malloc( 100*sizeof(int) ); if( p == NULL ) // 반환값이 NULL인지검사 { printf(" 동적메모리할당오류 \n"); exit(1); } for(i=0 ; i<100 ; i++) score[i] = 0; free(p); return 0; } 동적메모리할당 동적메모리해제

동적메모리할당 void *malloc(size_t size) size는바이트의수 malloc() 함수는메모리블럭의첫번째바이트에대한주소를반환 만약요청한메모리공간을할당할수없는경우에는 NULL값을반환 int *score; score = (int *)malloc(100*sizeof(int)); if( score == NULL ){... // 오류처리 } score?????

동적메모리사용 할당받은공간은어떻게사용하면좋을까? 첫번째방법 : 포인터를통하여사용 *score = 100; *(score+1) = 200; *(score+2) = 300;... 두번째방법 : 동적메모리를배열과같이취급 score[0] = 100; score[1] = 200; score[2] = 300;... score 100 200 300??

동적메모리반납 void free(void *ptr) free() 는동적으로할당되었던메모리블록을시스템에반납 ptr은 malloc() 을이용하여동적할당된메모리를가리키는포인터 int *score; score = (int *)malloc(100*sizeof(int)); free(score); score?????

예제 #include <stdio.h> #include <stdlib.h> int main(void) { char *pc = NULL; int i= 0; pc = (char *)malloc(100*sizeof(char)); if( pc == NULL ) { printf(" 메모리할당오류 \n"); exit(1); } for(i=0;i<26;i++){ pc[i] = 'a'+i; // 알파벳소문자를순서대로대입 } pc[i] = 0; // NULL 문자추가 printf("%s\n", pc); free(pc); return 0; } abcdefghijklmnopqrstuvwxyz

예제 struct Book { int number; char title[10]; }; int main(void) { struct Book *p; 구조체배열할당 } p = (struct Book *)malloc(2 * sizeof(struct Book)); if(p == NULL){ printf(" 메모리할당오류 \n") ; exit(1); } p->number = 1; strcpy(p->title,"c Programming"); (p+1)->number = 2; strcpy((p+1)->title,"data Structure"); free(p); return 0;

calloc() void *calloc(size_t n, size_t size); calloc() 은 0으로초기화된메모리할당 항목단위로메모리를할당 ( 예 ) int *p; p = (int *)calloc(5, sizeof(int)); malloc() p?????? calloc() p 0 0 0 0 0 0

realloc() void *realloc(void *memblock, size_t size); realloc() 함수는할당하였던메모리블록의크기를변경 ( 예 ) int *p; p = (int *)malloc(5 * sizeof(int))); p = realloc(p, 7 * sizeof(int))); malloc() 1 5 7 4 2 9 p realloc() p 1 5 7 4 2 9??

예제 #include <stdio.h> #include <stdlib.h> #define INCREMENT 100 // 한번에증가시키는크기 double *scores = NULL; int add_score(double new_score) { static int limit = 0; // 현재동적배열의최대크기 static int count = 0; // 현재동적배열의크기 if( count < limit ){ scores[count++]= new_score; } else { int new_limit = limit + INCREMENT; double *new_array = realloc(scores, new_limit*sizeof(double)); if( new_array == NULL ){ fprintf(stderr, " 메모리할당오류 \n"); } else { scores = new_array; limit = new_limit; scores[count++] = new_score; } return count; } }

예제 int main(void) { int i, size; double value, total=0.0; size = 3; for(i=0;i<size;i++) { printf(" 성적 : "); scanf("%lf", &value); add_score(value); } for(i=0;i<size;i++){ total += scores[i]; } printf(" 평균 : %f\n", total/size); return 0; } free(scores); 성적 : 10 성적 : 20 성적 : 30 평균 : 20.000000

중간점검 1. 프로그램의실행도중에메모리를할당받아서사용하는것을 이라고한다. 2. 동적으로메모리를할당받을때사용하는대표적인함수는 이다. 3. 동적으로할당된메모리를해제하는함수는 이다. 4. 동적메모리함수의원형은헤더파일 에정의되어있다.

중간점검 1. 동적할당후에메모리블록을초기화하여넘겨주는함수는 이다. 2. 할당되었던동적메모리의크기를변경하는함수는 이다. 3. 동적메모리할당에서의단위는 이다. 4. malloc() 이반환하는자료형은 이다.

연결리스트 배열 (array) 장점 : 구현이간단하고빠르다 단점 : 크기가고정된다. 중간에서삽입, 삭제가어렵다. 0 1 2 3 4 5 6 7 8 9 연결리스트 (linked list) 각각의원소가포인터를사용하여다음원소의위치를가리킨다. A C D E B 메인메모리

연결리스트의장단점 중간에데이터를삽입, 삭제하는경우 N A C D E A C D E B B 데이터삽입 데이터삭제 데이터를저장할공간이필요할때마다동적으로공간을만들어서쉽게추가 구현이어렵고오류가나기쉽다. 중간에있는데이터를빠르게가져올수없다.

연결리스트의구조 노드 (node) = 데이터필드 (data field)+ 링크필드 (link field) 연결리스트의노드는데이터필드와링크필드로이루어집니다. data link

연결리스트의구조 헤드포인터 (head pointer): 첫번째노드를가리키는포인터 첫번째노드를가리키는포인터를헤드포인터라고하고맨마지막노드의링크필드는 NULL 입니다. plist 10 20 30 NULL NULL 40 NULL 50 NULL

노드생성 노드들은동적으로생성된다.

자기참조구조체 자기참조구조체 (self-referential structure) 는특별한구조체로서구성멤버중에같은타입의구조체를가리키는포인터가존재하는구조체 typedef struct NODE { int data; struct NODE *link; } NODE;

간단한연결리스트생성 NODE *p1; p1 = (NODE *)malloc(sizeof(node)); p1->data = 10; p1->link = NULL; NODE *p2; p2 = (NODE *)malloc(sizeof(node)); p2->data = 20; p1 p1 10 NULL p2->link = NULL; p1->link = p2; free(p1); free(p2); p1 10 20 NULL p1 10 20 NULL

연결리스트의응용 소장하고있는책의목록을관리하는프로그램을작성 연결리스트를사용하여서작성

연결리스트를이용한프로그램

실행결과

중간점검 1. 연결리스트에서다음노드는 로가리킨다. 2. 연결리스트의일반적인노드는 필드와 필드로구성되어있다. 3. 구조체의멤버중에자기자신을가리키는포인터가존재하는구조체를 라고한다. 4. 배열과연결리스트의가장큰차이점은무엇인가?

실습 : 영화관리프로그램 구조체배열을동적메모리를이용하여서생성하고여기에영화정보를저장했다가다시화면에예쁘게출력하는프로그램을작성하여보자. 영화정보를사용자로부터받는다.

실행결과 몇편이나저장하시겠습니까? 1 영화제목 : 트랜스포머영화평점 :8.3 ======================== 제목평점 ======================== 트랜스포머 8.300000 ========================

힌트 이문제는물론정적배열을사용하면아주쉬운문제이지만여기서동적메모리할당을이용해보자. 동적메모리를사용하면사용자가원하는만큼의공간을실행시간에할당받을수있다. 먼저영화정보를다음과같이구조체로표현한다. typedef struct movie { // 구조체타입정의 char title[100]; // 영화제목 double rating; // 영화평점 } MOVIE; 사용자가입력하고자하는영화의수를 size에입력받은후에, 동적으로할당 movies = (MOVE *)malloc(sizeof(movie)* size); // 동적메모리할당

예제 #include <stdio.h> typedef struct movie { // 구조체타입정의 char title[100]; // 영화제목 double rating; // 영화평점 } MOVIE; int main(void) { MOVIE *movies; // 동적메모리공간을가리키는포인터 int size, i; printf(" 몇편이나저장하시겠습니까? "); scanf("%d", &size); movies = (MOVIE *)malloc(sizeof(movie)* size); // 동적메모리할당 if( movies == NULL ){ printf(" 동적메모리할당오류 ); exit(1); }

예제 } for(i=0; i<size ;i++) { // size편의영화정보입력 printf(" 영화제목 ); fflush(stdin); // 입력버퍼를비운다. gets(movies[i].title); // 영화제목에는빈칸이있을수있다. printf(" 영화평점 ); scanf("%lf", &(movies[i].rating)); } printf("========================\n"); printf(" 제목평점 ); printf("========================\n"); for(i=0;i<size;i++) printf("%s \t %f", movies[i].title, movies[i].rating); printf("\n========================\n"); free(movies); // 동적메모리공간해제 return 0;

도전문제 사용자가입력한데이터를파일에기록하는코드를추가해보자. 프로그램이시작할때파일에서데이터를읽어오는코드도추가하여보자.

Q & A

감사합니다.