<4D F736F F F696E74202D D20B9AEC0DABFAD2C20BDBAC6AEB8B2B0FA20C6C4C0CF20C0D4C3E2B7C2>

Similar documents
13 주차문자열의표현과입출력

11장 포인터

Microsoft PowerPoint - [CPI16] Lecture 10 - 문자열.pptx

11장 포인터

11장 포인터

이번장에서학습할내용 문자표현방법 문자열표현방법 문자열이란무엇인가? 문자열의입출력 문자처리라이브러리함수 표준입출력라이브러리함수 인간은문자를사용하여정보를표현하므로문자열은프로그램에서중요한위치를차지하고있다. 이번장에서는 C 에서의문자열처리방법에대하여자세히살펴볼것입니다. 2

Microsoft PowerPoint - chap-12.pptx

<4D F736F F F696E74202D20C1A63132C0E520B9AEC0DABFCD20B9AEC0DABFAD>

11장 포인터

11장 포인터

쉽게풀어쓴 C 언어 Express 제 12 장문자와문자열 이번장에서학습할내용 문자표현방법 문자열표현방법 문자열이란무엇인가? 문자열의입출력 문자처리라이브러리함수 표준입출력라이브러리함수 인간은문자를사용하여정보를표현하므로문자열은프로그램에서중요한위치를차지하

Microsoft PowerPoint - 제12장 문자열(강의)

11장 포인터

ch13

<4D F736F F F696E74202D D20B9AEC0DABFAD2C20BDBAC6AEB8B2B0FA20C6C4C0CF20C0D4C3E2B7C2>

Microsoft PowerPoint - C프로그래밍-chap15.ppt [호환 모드]

Microsoft PowerPoint - 10장 문자열 pptx

PowerPoint 프레젠테이션

Microsoft PowerPoint - chap06-4 [호환 모드]

PowerPoint 프레젠테이션

Microsoft PowerPoint - 06_(C_Programming)_(Korean)_Characters_Strings

YRRZBRRLMCEQ.hwp

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

PowerPoint Presentation

Microsoft PowerPoint - 제9강 문자열

< E20C6DFBFFEBEEE20C0DBBCBAC0BB20C0A7C7D12043BEF0BEEE20492E707074>

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

Microsoft PowerPoint - chap06-1Array.ppt

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

歯9장.PDF

: 1 int arr[9]; int n, i; printf(" : "); scanf("%d", &n); : : for(i=1; i<10; i++) arr[i-1] = n * i; for(i=0; i<9; i++) if(i%2 == 1) print

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

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

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


C 언어 프로그래밊 과제 풀이

C 프로그램의 기본

설계란 무엇인가?

중간고사

Microsoft PowerPoint - ch07 - 포인터 pm0415

PowerPoint 프레젠테이션

<4D F736F F F696E74202D20B8AEB4AABDBA20BFC0B7F920C3B3B8AEC7CFB1E22E BC8A3C8AF20B8F0B5E55D>

Microsoft PowerPoint - chap08.ppt

02장.배열과 클래스

목차 배열의개요 배열사용하기 다차원배열 배열을이용한문자열다루기 실무응용예제 C 2

<4D F736F F F696E74202D2034C5D8BDBAC6AEC6C4C0CFC0D4C3E2B7C2312E505054>

歯7장.PDF

chap7.PDF

11장 포인터

Microsoft PowerPoint - Chapter_08.pptx

PA for SWE2007

PowerPoint 프레젠테이션

프로그래밍개론및실습 2015 년 2 학기프로그래밍개론및실습과목으로본내용은강의교재인생능출판사, 두근두근 C 언어수업, 천인국지음을발췌수정하였음

OCW_C언어 기초

PowerPoint Presentation

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

03 상수, 변수, 자료형

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

PowerPoint Presentation

C++ Programming

슬라이드 1

untitled

Microsoft PowerPoint - chap03-변수와데이터형.pptx

Microsoft PowerPoint - C++ 5 .pptx

int main(void) int a; int b; a=3; b=a+5; printf("a : %d \n", a); printf("b : %d \n", b); a b 3 a a+5 b &a(12ff60) &b(12ff54) 3 a 8 b printf(" a : %x \

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

<322EBCF8C8AF28BFACBDC0B9AEC1A6292E687770>

<443A5C4C C4B48555C B3E25C32C7D0B1E25CBCB3B0E8C7C1B7CEC1A7C6AE425CBED0C3E0C7C1B7CEB1D7B7A55C D616E2E637070>

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

Microsoft PowerPoint - chap11.ppt [호환 모드]

untitled

PA0 for SSE2033

chap7.key

PowerPoint Presentation

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

Microsoft PowerPoint APUE(Intro).ppt

PA for SWE2007

Microsoft PowerPoint - 제11강 파일 처리

Microsoft PowerPoint - [2009] 02.pptx

Microsoft PowerPoint - 제11장 포인터

untitled

11장 포인터

<4D F736F F F696E74202D20C1A632B0AD20BAAFBCF6BFCD20C0DAB7E12C20C0FCC3B3B8AEBFCD20C0D4C3E2B7C2>

4. 1 포인터와 1 차원배열 4. 2 포인터와 2 차원배열 4. 3 포인터배열 4. 4 포인터와문자그리고포인터와문자열

<4D F736F F F696E74202D20C1A633C0E52043C7C1B7CEB1D7B7A5B1B8BCBABFE4BCD2>

설계란 무엇인가?

Microsoft PowerPoint - chap06-8 [호환 모드]

슬라이드 1

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

쉽게 풀어쓴 C 프로그래밍

Chapter_06

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

PowerPoint Presentation

PowerPoint Presentation

비트와바이트 비트와바이트 비트 (Bit) : 2진수값하나 (0 또는 1) 를저장할수있는최소메모리공간 1비트 2비트 3비트... n비트 2^1 = 2개 2^2 = 4개 2^3 = 8개... 2^n 개 1 바이트는 8 비트 2 2

Microsoft PowerPoint - chap12-고급기능.pptx

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

Microsoft PowerPoint - chap07.ppt [호환 모드]

Microsoft PowerPoint - chap06-8.ppt

쉽게 풀어쓴 C 프로그래밍

Transcription:

2015-1 5. 문자열 (string), 파일입출력 March 9, 2015 Advanced Networking Technology Lab. (YU-ANTL) Dept. of Information & Comm. Eng, College of Engineering, Yeungnam University, KOREA (Tel : +82-53-810-2497; Fax : +82-53-810-4742 http://antl.yu.ac.kr/; E-mail : ytkim@yu.ac.kr)

Outline 문자열 문자입출력라이브러리 문자열입출력라이브러리 문자처리라이브러리 문자열처리라이브러리함수 문자열수치변환 문자열의배열 파일입출력 예제프로그램 5-2

문자표현방법 컴퓨터에서는각각의문자에숫자코드를붙여서표시한다. 아스키코드 (ASCII code): 표준적인 8비트문자코드 0 에서 127 까지의숫자를이용하여문자표현 유니코드 (unicode): 표준적인 16 비트문자코드 전세계의모든문자를일관되게표현하고다룰수있도록설계 65 69 71 74 78 C 에서문자는숫자로표현됩니다. 5-3

문자열표현방법 문자열 (string): 문자들이여러개모인것 "A" "Hello World!" " 변수 score의값은 %d입니다 문자열은여러개의문자로이루어져있으므로문자배열로저장이가능해요. H 문자열의저장 문자배열사용 하나의문자는 char 형변수로저장 H E L L o \0 문자열은 char 형배열로저장 5-4

NULL 문자 NULL 문자 : 문자열의끝을나타낸다. 끝 NULL 문자는문자열의끝을나타냅니다. S E O U L \0 문자열은어디서종료되는지알수가없으므로표시를해주어야한다. seou, seoul, seoul#, seoul#%,...??? 쓰레기값 s e o u # l %? & $ str[0] str[1] str[2] str[3] str[4] str[5] str[6] str[7] str[8] str[9] 5-5

문자변수와문자상수 문자변수 문자상수 // 문자상수 #include <stdio.h> 65 int main(void) { char code1 = 'A'; char code2 = 65; printf("code1=%c, code1=%d\n", code1,code1); printf("code2=%c, code2=%d\n", code2,code2); return 0; code1=a, code1=65 code2=a, code2=65 5-6

아스키코드출력 // 아스키코드출력 #include <stdio.h> int main(void) { unsigned char code; 32 : ( 공백 ) 부터 127 : 까지출력 for(code = 32; code < 128; code++) { printf(" 아스키코드 %d은 %c입니다.\n", code, code); return 0; 아스키코드 32 은입니다. 아스키코드 33 은! 입니다.... 아스키코드 65 은 A 입니다. 아스키코드 66 은 B 입니다.... 아스키코드 97 은 a 입니다. 아스키코드 98 은 b 입니다.... 아스키코드 126 은 ~ 입니다. 아스키코드 127 은 입니다. 5-7

예제 #1 #include <stdio.h> int main(void) { int i; char str[4]; str[0] = 'a'; str[1] = 'b'; str[2] = 'c'; str[3] = '\0'; 문자배열에들어있는문자들을하나씩출력하여보자. 문자배열에저장된문자열을출력할때는 %s 를사용하면되지만여기서는문자열처리의기본적인방법을실감하기위하여문자배열에들어있는문자들을하나씩화면에출력하다가 NULL 문자가나오면반복을종료하도록하였다. i= 0; while(str[i]!= '\0') { printf("%c", str[i]); i++; return 0; abc 5-8

문자배열의초기화 char str[4] = { 'a', 'b', 'c', '\0' ; char str[4] = "abc ; char str[4] = "abcdef"; char str[6] = "abc"; char str[4] = ""; char str[] = "abc"; 5-9

문자열의출력 abc char str[] = abc ; printf( %s, str); char str[] = abc ; printf(str); 5-10

예제 #2 #include <stdio.h> int main(void) { char str1[6] = "Seoul ; char str2[3] = { i s, \0 ; char str3[] = "the capital city of Korea. ; Seoul is the capital city of Korea. printf("%s %s %s\n", str1, str2, str3); S e o u l \0 str1[0] str1[1] str1[2] str1[3] str1[4] str1[5] str1 i s \0 str2[0] str2[1] str2[2] str2... t h e K o r e a str3[ ] str3[ ] str3[ ] str3[ ].... str3[ ] str3[ ] str3[ ] str3[ ] str3[ ] str3[ ] \0 str3 5-11

예제 #3 #include <stdio.h> int main(void) { char src[] = "The worst things to eat before you sleep"; char dst[100]; int i; printf(" 원본문자열 =%s\n", src); for(i=0 ; src[i]!= NULL ; i++) dst[i] = src[i]; dst[i] = NULL; printf(" 복사된문자열 =%s\n", dst); return 0; NUL 문자가나올때까지반복하면서각각의문자들을새로운배열로복사한다. 원본문자열 =The worst things to eat before you sleep 복사된문자열 =The worst things to eat before you sleep 5-12

문자열길이계산예제 // 문자열의길이를구하는프로그램 #include <stdio.h> 문자열 "C language is easy" 의길이는 18 입니다. int main(void) { char str[30] = "C language is easy"; int i= 0; while(str[i]!= 0) i++; printf(" 문자열 \"%s\" 의길이는 %d 입니다.\n", str, i); return 0; C i s... e a s y str[0] str[1] str[2] str[3].... str[13] str[14] str[15] str[16] str[17] str[18] str[19].... str[28] str[29] 종료 ( \0 의아스키 코드값은 0이다 ) \0... str[18] == 0 이므로카운터 15 14 18 01234 i 5-13

문자배열에문자열을저장 1. 각각의문자배열원소에원하는문자를개별적으로대입하는방법이다. str[0] = 'W'; str[1] = 'o'; str[2] = 'r'; str[3] = 'l'; str[4] = 'd'; str[5] = ' 0'; 2. strcpy() 를사용하여문자열을문자배열에복사 strcpy(str, "World"); // 추후에학습 5-14

문자열상수 문자열상수 : HelloWorld 와같이프로그램소스안에포함된문자열 문자열상수는메모리영역중에서텍스트세그먼트 (text segment) 에저장 char *p = "HelloWorld"; 위문장의정확한의미는무엇일까요? 5-15

문자열상수 char *p = "HelloWorld"; 5-16

문자열상수 char *p = "HelloWorld"; p[0] = A ; // 또는 strcpy(p, Goodbye ); p 를통하여텍스트세그먼트에문자를저장하려면오류가발생한다. 5-17

문자열상수 char *p = "HelloWorld"; p = "Goodbye"; OK! 5-18

문자입출력라이브러리 입출력함수 설명 int getchar(void) 하나의문자를읽어서반환한다. void putchar(int c) 변수 c에저장된문자를출력한다. int getch(void) 하나의문자를읽어서반환한다 ( 버퍼를사용하지않음 ). void putch(int c) 변수 c에저장된문자를출력한다 ( 버퍼를사용하지않음 ). scanf("%c", &c) 하나의문자를읽어서변수 c에저장한다. printf("%c", c); 변수 c에저장된문자를출력한다. 5-19

getchar(), putchar() // getchar() 의사용 #include <stdio.h> int main(void) { int ch; // 정수형에주의 while( (ch = getchar())!= EOF ) putchar(ch); return 0; AB^Z A A B B ^Z 입력 출력 ch 5-20

버퍼링 엔터키를쳐야만입력을받는이유 모든문자는일단버퍼로간다. 엔터키 (\n) 가입력되면모두프로그램으로간다. #include <stdio.h> int main(void) { char ch; ch = getchar();...... 키보드 버퍼 프로그램 5-21

getch(), putch() #include <stdio.h> #include <conio.h> int main(void) { int ch; while( (ch = getch())!= 'q' ) putch(ch); return 0; 버퍼를사용하지않는다 ABCDEFGH 출력 5-22

getch(), getche(), getchar() getchar() 헤더파일 <stdio.h> 버퍼사용여부 사용함 ( 엔터키를눌러입력됨 ) 에코여부 응답성 문자수정여부 에코줄단위가능 getch() <conio.h> 사용하지않음 에코하지않음 문자단위 불가능 getche() <conio.h> 사용하지않음 에코 문자단위 불가능 용도에맞는것을골라사용하세요! 버퍼가없이바로받으려면 getch() 를사용합니다. 5-23

문자열입출력라이브러리함수 입출력함수 설명 int scanf("%s", s) 문자열을읽어서문자배열 s[] 에저장 int printf("%s", s) 배열 s[] 에저장되어있는문자열을출력한다. char *gets(char *s) 한줄의문자열을읽어서문자배열 s[] 에저장한다. int puts(const char *s) 배열 s[] 에저장되어있는한줄의문자열을출력한다. Hello World!... 프로그램 5-24

gets() 와 puts() 문자열입출력 char *gets(char *buffer); int puts(const char *str); gets() 표준입력으로부터엔터키가나올때까지한줄의라인을입력 문자열에줄바꿈문자 (' n') 는포함되지않으며대신에자동으로 NULL 문자 (' 0') 를추가한다. 입력받은문자열은 buffer가가리키는주소에저장된다. 5-25

gets() 와 puts() 문자열입출력 char *gets(char *buffer); int puts(const char *str); puts() str이가리키는문자열을받아서화면에출력 NULL 문자 (' 0') 는줄바꿈문자 (' n') 로변경 char *menu = " 파일열기 : open, 파일닫기 : close"; puts(str); 5-26

예제 #include <stdio.h> int main(void) { char name[100]; char address[100]; printf(" 이름을입력하시오 : "); gets(name); printf(" 현재거주하는주소를입력하시오 : "); gets(address); puts(name); puts(address); return 0; 한단어이상을입력받을때에사용한다. 이름을입력하시오 : 홍길동현재거주하는주소를입력하시오 : 서울시종로구 100 번지홍길동서울시종로구 100 번지 5-27

문자처리라이브러리함수 문자를검사하거나문자를변환한다. 함수 설명 isalpha(c) c가영문자인가?(a-z, A-Z) isupper(c) c가대문자인가?(a-z) islower(c) c가소문자인가?(a-z) isdigit(c) c가숫자인가?(0-9) isalnum(c) c가영문자이나숫자인가?(a-z, A-Z, 0-9) isxdigit(c) c가 16진수의숫자인가?(0-9, A-F, a-f) isspace(c) c가공백문자인가?(, \n', '\t', '\v', '\r') ispunct(c) c가구두점문자인가? isprint(c) C가출력가능한문자인가? iscntrl(c) c가제어문자인가? isascii(c) c가아스키코드인가? 5-28

문자처리라이브러리함수 문자를검사하거나문자를변환한다. 함수 설명 toupper(c) c를대문자로바꾼다. tolower(c) c를소문자로바꾼다. toascii(c) c를아스키코드로바꾼다. 5-29

예제 #include <stdio.h> #include <ctype.h> int main( void ) { int c; 소문자인지검사 대문자로변환 while((c = getchar())!= EOF) { if( islower(c) ) c = toupper(c); putchar(c); return 0; abcdef ABCDEF ^Z 5-30

예제 #include <stdio.h> #include <conio.h> #include <ctype.h> int main( void ) { int c; while((c = getch())!= 'z') { printf("------------------------\n"); printf("isdigit(%c) = %d\n", c, isdigit(c)); printf("isalpha(%c) = %d\n", c, isalpha(c)); printf("islower(%c) = %d\n", c, islower(c)); printf("ispunct(%c) = %d\n", c, ispunct(c)); printf("isxdigit(%c) = %d\n", c, isxdigit(c)); printf("isprint(%c) = %d\n", c, isprint(c)); printf("------------------------\n\n"); return 0; 숫자인지검사알파벳인지검사소문자인지검사구두점문자인지검사 16진수인지검사 출력가능한지검사 ------------------------ isdigit(') = 0 isalpha(') = 0 islower(') = 0 ispunct(') = 16 isxdigit(') = 0 isprint(') = 16 ------------------------... 5-31

문자열처리라이브러리 함수 설명 strlen(s) 문자열 s의길이를구한다. strcpy(s1, s2) s2를 s1에복사한다. strcat(s1, s2) s2를 s1의끝에붙여넣는다. strcmp(s1, s2) s1과 s2를비교한다. strncpy(s1, s2, n) s2의최대n개의문자를 s1에복사한다. strncat(s1, s2, n) s2의최대n개의문자를 s1의끝에붙여넣는다. strncmp(s1, s2, n) 최대 n개의문자까지 s1과 s2를비교한다. strchr(s, c) 문자열 s안에서문자 c를찾는다. strstr(s1, s2) 문자열 s1에서문자열 s2를찾는다. W o r l d H e l l o 5-32

문자열의길이 strlen( Hello ) 는 5 를반환 문자열길이 (strlen) 5-33

문자열복사 char dst[6]; char src[6] = Hello"; strcpy(dst, src); 문자열복사 (strcpy) src H e l l o \0 dst H e l l o \0 5-34

문자열연결 문자열연결 char dst[12] = "Hello"; char src[6] = "World"; strcat(dst, src); H e l l o \0 W o r l d \0 dst src 5-35

예제 // strcpy 와 strcat #include <string.h> #include <stdio.h> int main( void ) { char string[80]; strcpy( string, "Hello world from " ); strcat( string, "strcpy " ); strcat( string, "and " ); strcat( string, "strcat!" ); printf( "string = %s\n", string); return 0; 복사하기문자열연결문자열연결 문자열연결 string = Hello world from strcpy and strcat! 5-36

문자열비교 int strcmp( const char *s1, const char *s2 ); 반환값 s1과 s2의관계 <0 s1이 s2보다작다 0 s1이 s2와같다. >0 s1이 s2보다크다. s1 s t r c m p \0 s2 = = = = > s t r c p y \0 m 이 p 보다아스키코드값이작으므로음수가반환된다. 5-37

예제 // strcmp() 함수 #include <string.h> #include <stdio.h> int main( void ) { char s1[80]; char s2[80]; int result; // 첫번째단어를저장할문자배열 // 두번째단어를저장할문자배열 첫번째단어를입력하시오 :Hello 두번째단어를입력하시오 :World Hello 가 World 보다앞에있습니다. printf(" 첫번째단어를입력하시오 :"); scanf("%s", s1); printf(" 두번째단어를입력하시오 :"); scanf("%s", s2); result = strcmp(s1, s2); if( result < 0 ) printf("%s 가 %s 보다앞에있읍니다.\n", s1, s2); else if( result == 0 ) printf("%s 가 %s 와같습니다.\n", s1, s2); else printf("%s 가 %s 보다뒤에있습니다.\n", s1, s2); return 0; 5-38

문자검색 #include <string.h> #include <stdio.h> int main( void ) { char s[] = "language"; char c = 'g'; char *p; int loc; s 안에서문자 c 를찾는다. p = strchr(s, c); loc = (int)(p - s); if ( p!= NULL ) printf( " 첫번째 %c가 %d에서발견되었음 \n", c, loc ); else printf( "%c가발견되지않았음 \n", c ); return 0; 첫번째 g가 3에서발견되었음 5-39

문자열검색 #include <string.h> #include <stdio.h> int main( void ) { char s[] = "A joy that's shared is a joy made double"; char sub[] = "joy"; char *p; s 안에서문자열 sub를찾는다. int loc; p = strstr(s, sub); loc = (int)(p - s); if ( p!= NULL ) printf( " 첫번째 %s가 %d에서발견되었음 \n", sub, loc ); else printf( "%s가발견되지않았음 \n", sub ); 첫번째 joy가 2에서발견되었음 5-40

strtok() 형식 char *strtok( char *s, const char *delimit ); 설명 strtok 함수는문자열 s 을토큰으로분리한다. 만약분리자가 일경우, 토큰을얻으려면다음과같이호출한다. t1 = strtok(s, " "); // 첫번째토큰 t2 = strtok(null, " "); // 두번째토큰 t3 = strtok(null, " "); // 세번째토큰 t4 = strtok(null, " "); // 네번째토큰 5-41

문자열토큰분리 // strtok 함수의사용예 #include <string.h> #include <stdio.h> char s[] = "Man is immortal, because he has a soul"; char seps[] = ",\t\n"; char *token; int main( void ) { // 문자열을전달하고다음토큰을얻는다. token = strtok( s, seps ); while( token!= NULL ) { // 문자열 s 에토큰이있는동안반복한다. printf( " 토큰 : %s\n", token ); // 다음토큰을얻는다. token = strtok( NULL, seps ); // 분리자 토큰 :Man 토큰 :is 토큰 : immortal 토큰 :because 토큰 :he 토큰 :has 토큰 :a 토큰 :soul 5-42

문자열수치변환 문자열과수치 3 6. 5 \0 src[0] src[1] src[2] src[3] src[4] src[5] 36.5 v 문자열 수치 scanf() 함수는문자열을수치로변환한다. 3 6. 5 \0 36.5 scanf()... scanf( %f, x);... scanf() 가키보드에서입력된문자열을숫자로변환합니다.. 5-43