untitled

Similar documents
Microsoft PowerPoint - Lesson12.pptx

Microsoft PowerPoint - chap-13.pptx

이번장에서학습할내용 구조체란무엇인가? 구조체의선언, 초기화, 사용 구조체의배열 구조체와포인터 구조체와함수 공용체 열거형 typedef 구조체는복잡한내용을일목요연하여정리하는데유용하게사용됩니다. 2

11장 포인터

14 주차구조체와공용체

Microsoft PowerPoint - 제13장 구조체

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

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

기초컴퓨터프로그래밍

untitled

슬라이드 1

untitled

Microsoft PowerPoint - 3ÀÏ°_º¯¼ö¿Í »ó¼ö.ppt

K&R2 Reference Manual 번역본

untitled

Microsoft PowerPoint - Chapter_09.pptx

; struct point p[10] = {{1, 2, {5, -3, {-3, 5, {-6, -2, {2, 2, {-3, -3, {-9, 2, {7, 8, {-6, 4, {8, -5; for (i = 0; i < 10; i++){ if (p[i].x > 0 && p[i

BACK TO THE BASIC C++ 버그 헌팅: 버그를 예방하는 11가지 코딩 습관

03장.스택.key

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 \

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

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

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


Microsoft PowerPoint - 07_(C_Programming)_(Korean)_Composite_Data_Types


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

중간고사

歯9장.PDF

chap8.PDF

프로그램을 학교 등지에서 조금이라도 배운 사람들을 위한 프로그래밍 노트 입니다. 저 역시 그 사람들 중 하나 입니다. 중고등학교 시절 학교 도서관, 새로 생긴 시립 도서관 등을 다니며 책을 보 고 정리하며 어느정도 독학으르 공부하긴 했지만, 자주 안하다 보면 금방 잊어

Hanyang Volunteer Corps volunteer image

본 강의에 들어가기 전

13주-14주proc.PDF

<4D F736F F F696E74202D20C1A63132B0AD20B5BFC0FB20B8DEB8F0B8AEC7D2B4E7>

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


<C7E0BAB9C0AFBCBA5F F30365F322E696E6464>

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

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

Microsoft PowerPoint - chap12-고급기능.pptx

F.

chap7.key


<322EBCF8C8AF28BFACBDC0B9AEC1A6292E687770>

5월고용내지

11장 포인터

06.._ _12...._....

< E20C6DFBFFEBEEE20C0DBBCBAC0BB20C0A7C7D12043BEF0BEEE20492E707074>

02장.배열과 클래스

PowerPoint 프레젠테이션

chap10.PDF

Microsoft PowerPoint - 제11장 포인터

C++-¿Ïº®Çؼ³10Àå

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

PowerPoint 프레젠테이션

06³â_±â»ÝÀÇ»ù_10¿ùÈ£_À¥Áø

Microsoft PowerPoint - chap09-1.ppt

PowerPoint 프레젠테이션

독립기념관 7월호 3p

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



PowerPoint 프레젠테이션

Microsoft PowerPoint - chap-11.pptx

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

, ( ),, ( ), 3, int kor[5]; int eng[5]; int Microsoft Windows 4 (ANSI C2 ) int kor[5] 20 # define #define SIZE 20 int a[10]; char c[10]; float

PowerPoint 프레젠테이션

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


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

02 C h a p t e r Java

: 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

11장 포인터

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

Microsoft Word - retail_ doc

C 언어의구성요소인상수, 변수, 입 출력함수에 대하여학습

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

시설공단-11월도큐

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

½Å³âÈ£-Ç¥Áö

10장. 구조체


Microsoft PowerPoint - ch07 - 포인터 pm0415

歯3일_.PDF

<4D F736F F F696E74202D20C1A63134C0E520C6F7C0CEC5CD5FC8B0BFEB>

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

¼Ł¿ï¸ðµåÃÖÁ¾

슬라이드 1

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

ABC 9장

OCW_C언어 기초

<4D F736F F F696E74202D20C1A63137C0E520B5BFC0FBB8DEB8F0B8AEBFCD20BFACB0E1B8AEBDBAC6AE>

슬라이드 1

C 프로그래밊 개요

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

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

untitled

여름호-내지원본

KNK_C_05_Pointers_Arrays_structures_summary_v02

Transcription:

자료형 기본자료형 : char, int, float, double 등 파생자료형 : 배열, 열거형, 구조체, 공용체 vs

struct 구조체 _ 태그 _ 이름 자료형멤버 _ 이름 ; 자료형멤버 _ 이름 ;... ; struct student int number; // char name[10]; // double height; // ;

// x값과 y값으로이루어지는화면의좌표 struct point int x; // x 좌표 int y; // y 좌표 ; // 복소수 struct complex double real; double imag; ; // 날짜 struct date int month; int day; int year; ; // 실수부 // 허수부 // 사각형 struct rect int x; int y; int width; int height; ; // 직원 struct employee ; char name[20]; int age; int gender; int salary; // 이름 // 나이 // 성별 // 월급

struct student int number; char name[20]; double height; ; int main(void) struct student s1;...

struct student int number; char name[10]; double height; ; struct student s1 = 24, "Kim", 178.9 ;

s1.number = 26; strcpy(s1.name, "Kim"); s1.height = 183.2; // // //.

struct date int year; int month; int day; ; // struct student // int number; char name[10]; struct date dob; // double height; ; struct student s1; // s1.dob.year = 1983; s1.dob.month = 03; s1.dob.day = 29; //

#include <stdio.h> #include <stdlib.h> struct student int number; char name[10]; double height; ; int main(void) struct student s; s.number = 20070001; strcpy(s.name," "); s.height = 180.2; printf(": %d\n", s.number); printf(": %s\n", s.name); printf(": %f\n", s.height); return 0; : 20070001 : : 180.200000

struct student : 20070001 int number; : char name[10]; (): 180.2 double height; : 20070001 ; : : 180.200000 int main(void) struct student s; printf(" : "); scanf("%d", &s.number); printf(" : "); scanf("%s", s.name); printf(" (): "); scanf("%lf", &s.height); printf(": %d\n", s.number); printf(": %s\n", s.name); printf(": %f\n", s.height); return 0;

#include <math.h> struct point int x; int y; ; p2 (x,y) int main(void) struct point p1, p2; int xdiff, ydiff; double dist; printf(" (x y): "); scanf("%d %d", &p1.x, &p1.y); printf(" (x y): "); scanf("%d %d", &p2.x, &p2.y); p1 (x,y) xdiff = p1.x - p2.x; ydiff = p1.y - p2.y; dist = sqrt(xdiff * xdiff + ydiff * ydiff); printf(" %f.\n", dist); return 0; (x y): 10 10 (x y): 20 20 14.142136.

struct point int x; int y; ; p1(x,y) struct rect struct point p1; struct point p2; ; p2(x,y) int main(void) struct rect r; int w, h, area, peri; printf(" : "); scanf("%d %d", &r.p1.x, &r.p1.y); printf(" : "); scanf("%d %d", &r.p2.x, &r.p2.y); : 11 : 6 6 25 20. w = r.p2.x - r.p1.x; h = r.p2.x - r.p1.x; area = w * h; peri = 2 * w + 2 * h; printf(" %d %d.\n", area, peri); return 0;

struct point int x; int y; ; int main(void) struct point p1 = 10, 20; struct point p2 = 30, 40; p2 = p1; // if( p1==p2) // -> 컴파일오류!! printf("p1 와 p2 이같습니다.") if( (p1.x == p2.x) && (p1.y == p2.y) ) // printf("p1와 p2이같습니다.")

struct student int number; char name[20]; double height; ; int main(void) struct student list[100]; // list[2].number = 27; strcpy(list[2].name, " 홍길동 "); list[2].height = 178.0; struct student list[3] = 1, "Park", 172.8, 2, "Kim", 179.2, 3, "Lee", 180.3 ;

#define SIZE 3 : 20070001 : struct student (): 180.2 int number; : 20070002 char name[20]; : double height; (): 178.3 ; int main(void) struct student list[size]; int i; for(i = 0; i < SIZE; i++) printf(" : "); scanf("%d", &list[i].number); printf(" : "); scanf("%s", list[i].name); printf(" (): "); scanf("%lf", &list[i].height); : 20070003 : (): 176.3 : 20070001, :, : 180.200000 : 20070002, :, : 178.300000 : 20070003, :, : 176.300000 for(i = 0; i< SIZE; i++) printf(": %d, : %s, : %f\n", list[i].number, list[i].name, list[i].height); return 0;

struct student *p; struct student s = 20070001, " 홍길동 ", 180.2 ; struct student *p; p = &s; pintf(" printf(" 학번 =%d 이름 =%s 키 =%f \n", snumb s.number, sn s.name, sh s.height); ht); printf(" 학번 =%d 이름 =%s 키 =%f \n", (*p).number,(*p).name,(*p).height);

struct student *p; struct student s = 20070001, " 홍길동 ", 180.2 ; struct student *p; p = &s; printf(" 학번 =%d 이름 =%s 키 =%f \n", s.number, s.name, s.height); printf(" 학번 =%d 이름 =%s 키 =%f \n", (*p).number,(*p).name,(*p).height); printf(" 학번 =%d 이름 =%s 키 =%f \n", p->number, p->name, p->height); (*p).number p p number == p->number p number

// #include <stdio.h> struct student int number; char name[20]; double height; ; int main(void) struct student s = 20070001, " ", 180.2 ; struct student *p; p = &s; printf("=%d =%s % =%f \n", s.number, s.name, s.height); h printf("=%d =%s =%f \n", (*p).number,(*p).name,(*p).height); printf("=%d =%s =%f \n", p->number, p->name, p->height); return 0; =20070001 = =180.200000 =20070001 = =180.200000 =20070001 = =180.200000

struct date int month; int day; int year; ; struct student int number; char name[20]; double height; struct date *dob; ; int main(void) struct t date d = 3, 20, 1980 ; struct student s = 20070001, "Kim", 180.2 ; : 20070001 : Kim : 180.200000 : 1980 3 20 s.dob = &d; printf(": %d\n", s.number); printf(": %s\n", s.name); printf(": %f\n", s.height); printf(": %d %d %d \n", s.dob->year, s.dob->month, s.dob->day); return 0;

struct student int number; char name[10]; double height; struct student *next; ; int main(void) struct student s1 = 30, "Kim", 167.2, NULL ; struct student s2 = 31, "Park", 179.1, NULL ; struct student *first = NULL; struct student *current = NULL; first = &s1; s1.next = &s2; s2.next = NULL; current = first; while( current!= NULL ) printf(" =%d =%s, =%f\n", current->number, current->name, current->height); current = current->next; =30 =Kim, =167.200000 =31 =Park, =179.100000

int equal(struct student s1, struct student s2) if( strcmp(s1.name, s2.name) == 0 ) return 1; else return 0; int equal(struct student const *p1, p, struct student const *p2) if( strcmp(p1->name, p2->name) == 0 ) return 1; else return 0;

struct student make_student(void) struct student s; printf(": ); scanf("%d", &s.age); printf(": ); scanf("%s", s.name); printf(" : ); scanf("%f", &s.height); s. return s;

#include <stdio.h> struct vector float x; float y; ; struct vector get_vector_sum(struct vector a, struct vector b); int main(void) struct vector a = 2.0, 3.0 ; struct vector b = 5.0, 6.0 ; struct vector sum; sum = get_vector_sum(a, b); printf(" (%f, %f).\n", sum.x, sum.y); a + b a b return 0; struct vector get_vector_sum(struct vector a, struct vector b) struct vector result; result.x = a.x + b.x; result.y = a.y + b.y; return result; (7.000000, 9.000000).

#include <stdio.h> struct point int x; int y; ; // y int get_line_parameter(struct point p1, struct point p2, float *slope, float *yintercept) if( p1.x == p2.x ) return (-1); else *slope = (float)(p2.y - p1.y)/(float)(p2.x - p1.x); *yintercept = p1.y - (*slope) * p1.x; return (0); int main(void) struct point pt1 = 3, 3, pt2 = 6, 6; float s,y; if( get_line_parameter(pt1, pt2, &s, &y) == -1 ) printf(": x.\n"); else printf(" %f, y %f\n", s, y); return 0; 1.000000, y 0.000000

union example char c; // int i; // ;

#include <stdio.h> union example int i; char c; ; int main(void) union example v;. char. v.c = 'A'; printf("v v.c:%c v.i:%i\n i:%i\n", vc v.c, vi v.i ); v.i = 10000; printf("v.c:%c v.i:%i\n", v.c, v.i); int. v.c:a v.i:65 v.c: v.i:10000

#include <stdio.h> union ip_address unsigned long laddr; unsigned char saddr[4]; ; int main(void) union ip_address addr; addr.saddr[0] = 1; addr.saddr[1] [] = 0; addr.saddr[2] = 0; addr.saddr[3] = 127; printf("%x\n", addr.laddr); return 0; 7f000001

#include <stdio.h> #define STU_NUMBER 1 #define REG_NUMBER 2 struct student int type; union int stu_number; // char reg_number[15]; id; char name[20]; ; void print(struct student s) switch(s.type) // case STU_NUMBER: printf(": %d\n", s.id.stu_number); printf(": %s\n", s.name); break case REG_NUMBER: printf(": %d\n", s.id.reg_number); printf(": %s\n", s.name); break default: printf("\n"); break

int main(void) struct student s1, s2; s1.type = STU_NUMBER; s1.id.stu_number = 20070001; strcpy(s1.name, " "); s2.type = REG_NUMBER; strcpy(s2.id.reg_number, "860101-1058031"); strcpy(s2.name, " "); print(s1); print(s2); return 0; : 20070001 : : 1244868 :

enum _ 1, 2,... ; enum days1 MON, TUE, WED, THU, FRI, SAT, SUN ; enum days2 MON=1, TUE, WED, THU, FRI, SAT, SUN ; enum days3 MON=1, TUE=2, WED=3, THU=4, FRI=5, SAT=6, SUN=7 ; enum days4 MON, TUE=2, WED=3, THU, FRI, SAT, SUN ; enum days1 d; d=wed;

enum days SUN, MON, TUE, WED, THU, FRI, SAT ; enum colors white, red, blue, green, black ; enum boolean 0, 1 ; enum months JAN, FEB, MAR, APR, MAY, JUN, JUL, AUG, SEP, OCT, NOV, DEC ; enum major COMMUNICATION, COMPUTER, ELECTRIC, ELECTRONICS ; enum component MAIN_BOARD, CPU, GRAPHIC_CARD, DISK, MEMORY ; enum levels low = 1, medium, high ; enum CarOptions SunRoof = 0x01, Spoiler = 0x02, FogLights = 0x04, TintedWindows = 0x08,

switch(code) case 1: printf("lcd TV\n"); break; case 2: printf("pdp TV\n"); break;. #define LCD 1 #define PDP 2 enum tvtype LCD, PDP ; enum tvtype code; switch(code) case LCD: printf("lcd TV\n"); switch(code) case LCD: printf("lcd TV\n"); break; break; case PDP: case PDP: printf("pdp TV\n"); printf("pdp TV\n"); break; break;..

// #include <stdio.h> enum days MON, TUE, WED, THU, FRI, SAT, SUN ; char *days_name[] = "monday", "tuesday", "wednesday", "thursday", "friday", "saturday", "sunday" ; int main(void) enum days d; for(d=mon; d<=sun; d++) printf("%d %s \n", d, days_name[d]); 0 monday 1 tuesday 2 wednesday 3 thursday 4 friday 5 saturday 6 sunday

#include <stdio.h> enum tvtype tube, lcd, plasma, projection ; int main(void) id) enum tvtype type; TV : 3 TV. printf("tv : "); scanf("%d", &type); switch(type) case tube: printf(" TV.\n \n"); break; return 0; case lcd: printf("lcd TV.\n"); break; case plasma: printf("pdp TV.\n"); break; case projection: printf(" TV.\n"); break; default: printf(".\n"); break;

typedef old_type new_type; 새로운자료형을정의 typedef unsigned char BYTE; 기존의자료형 새로운자료형 point typedef 기본자료형 int float

int short unsigned int unsigned short unsigned char char typedef int INT32; typedef unsigned int UINT32; INT32 i; // int i; 와같다. UINT32 k; // unsigned int k; 와같다. typedef struct point int x; int y; POINT; POINT p,q; INT32 INT16 UINT32 UINT16 UCHAR, BYTE CHAR typedef struct complex double real; double imag; COMPLEX; COMPLEX x, y; typedef enum FALSE, TRUE BOOL; BOOL condition; // enum FALSE, TRUE condition; typedef char * STRING_PTR; STRING_PTR p; // char *p;

#include <stdio.h> typedef struct point int x; int y; POINT; POINT translate(point p, POINT delta); int main(void) POINT p = 2, 3 ; POINT delta = 10, 10 ; POINT result; result = translate(p, delta); printf(" (%d, %d).\n", result.x, result.y); return 0; POINT translate(point p, POINT delta) POINT new_p; new_p.x = p.x + delta.x; new_p.y = p.y + delta.y; return new_p; (12, 13).