Hệ thống máy tính và ngôn ngữ C

Một ngôn ngữ lập trình (NNLT) bậc cao cho phép người sử dụng (NSD) biểu hiện ý tưởng của mình để giải quyết một vấn đề, bài toán bằng cách diễn đạt gần với ngôn ngữ thông thường thay vì phải diễn đạt theo ngôn ngữ máy (dãy các kí hiệu 0,1). Hiển nhiên, các ý tưởng NSD muốn trình bày phải được viết theo một cấu trúc chặt chẽ thường được gọi là thuật toán hoặc giải thuật và theo đúng các qui tắc của ngôn ngữ gọi là cú pháp hoặc văn phạm. Trong giáo trình này chúng ta bàn đến một ngôn ngữ lập trình như vậy, đó là ngôn ngữ lập trình C++ và làm thế nào để thể hiện các ý tưởng giải quyết vấn đề bằng cách viết thành chương trình trong C++.

pdf599 trang | Chia sẻ: tlsuongmuoi | Lượt xem: 2831 | Lượt tải: 2download
Bạn đang xem trước 20 trang tài liệu Hệ thống máy tính và ngôn ngữ C, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
danh_saùch_teân_bieán; vôùi kieåu laø kieåu khai baùo cho bieán, kieåu naøy chæ coù theå laø int, char, unsigned, long hoaëc pointer HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 10.4 BIEÁN REGISTER Ví duï: register int i; register char c; register unsigned u; resister long l; register int *r; register t; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 10.4 BIEÁN REGISTER Taàm söû duïng vaø thôøi gian toàn taïi cuûa caùc bieán thanh ghi töông töï nhö caùc bieán cuïc boä, nhöng chuùng ñöôïc truy xuaát nhanh hôn caùc bieán cuïc boä bình thöôøng vì chuùng chính laø caùc thanh ghi cuûa boä vi xöû ly. Caùc bieán thanh ghi thöôøng ñöôïc söû duïng laøm caùc bieán ñieàu khieån trong caùc voøng laëp hoaëc caùc bieán phaûi truy xuaát nhieàu laàn trong chöông trình. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 10.5 KHÔÛI ÑOÄNG TRÒ CHO BIEÁN ÔÛ CAÙC LÔÙP Ñoái vôùi bieán toaøn cuïc hoaëc bieán tónh, ngay sau khi ñöôïc khai baùo, moãi bieán seõ ñöôïc C töï ñoäng gaùn trò laø 0. Trong khi ñoù bieán töï ñoäng vaø bieán thanh ghi seõ coù giaù trò khoâng xaùc ñònh (goïi laø trò raùc). trò baèng moät bieåu thöùc haèng. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 10.5 KHÔÛI ÑOÄNG TRÒ CHO BIEÁN ÔÛ CAÙC LÔÙP Trong suoát quaù trình chaïy chöông trình, bieán toaøn cuïc vaø bieán tónh chæ coù theå ñöôïc khôûi ñoäng trò moät laàn, ñoù laø laàn ñaàu tieân maø khai baùo bieán ñoù ñöôïc thöïc thi. Bieán toaøn cuïc vaø bieán tónh coù theå ñöôïc khôûi ñoäng trò baèng moät bieåu thöùc haèng. Bieán töï ñoäng vaø bieán thanh ghi coù theå ñöôïc khôûi ñoäng trò baèng moät bieåu thöùc maø giaù trò cuûa bieåu thöùc tôùi luùc ñoù ñaõ xaùc ñònh(coù theå goïi haøm). HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 10.5 KHÔÛI ÑOÄNG TRÒ CHO BIEÁN ÔÛ CAÙC LÔÙP Vieäc khôûi ñoäng cho caùc bieán thuoäc kieåu döõ kieän coù caáu truùc nhö maûng (array), struct vaø union chæ coù theå thöïc hieän ñöôïc ñoái vôùi caùc bieán toaøn cuïc hoaëc bieán tónh maø thoâi HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 10.6 SÖÏ CHUYEÅN KIEÅU Khi thöïc hieän caùc pheùp toaùn soá hoïc hoaëc luaân lyù, C luoân thöïc hieän söï chuyeån kieåu töï ñoäng. C coøn cho pheùp laäp trình vieân thöïc hieän vieäc chuyeån kieåu baét buoäc, eùp kieåu (type casting). Cuù phaùp ñeå eùp kieåu moät bieán, haèng hay bieåu thöùc: (type) giaù_trò HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 10.6 SÖÏ CHUYEÅN KIEÅU Ví duï: Cho khai baùo bieán sau: int a = 10, b = 3; double d; bieåu thöùc naøo cho keát quaû ñuùng, giaûi thích?(xem laïi thöù töï öu tieân caùc pheùp toaùn cuûa C) a) d = (double)(a/b); b) d = (double)a/b; c) d = a/(double)b; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C BAØI TAÄP CUOÁI CHÖÔNG 1. Vieát moät haøm sao cho moãi laàn goïi haøm thì haøm seõ traû veà moät trò soá ngay sau trò tröôùc ñoù trong daõy soá Fibonaci. 2. Vieát chöông trình vôùi caùc haøm tính caùc bieåu thöùc sau ñaây: duøng vaø khoâng duøng bieán thanh ghi ... ... ( ) ... ( ) ... ! ( )! ( )! ! + + + + − + + − = − + − + − − 1 n 1 n 1 1 n 2 1t n n 1 n 2 1 ( ... ) ( ... ( )) ( ... ( )) ... ! ! ( )! ( )! ... ! + + + + + − + + + − + + = + − + − + + 1 n 1 n 1 1 n 2 1T n n 1 n 2 1 HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C BAØI TAÄP CUOÁI CHÖÔNG 3. Vieát moät chöông trình goàm hai module: main.c vaø func.c, trong ñoù module main.c löu haøm main() coù caùc leänh goïi nhaäp ba heä soá cuûa tam thöùc baäc hai, kieåm tra in aán; coøn trong module func.c löu caùc haøm caàn thieát ñeå giaûi phöông trình baäc hai vaø bieän luaän tam thöùc baäc hai. 4. In ra maøn hình caùc soá nguyeân toá töø 1 ñeán 1.000. Duøng bieán thanh ghi vaø khoâng duøng bieán thanh ghi. Kieåm tra thôøi gian. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C KEÁT THUÙC CHÖÔNG 10 HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C CHÖÔNG 11 MAÛNG HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C CHÖÔNG 11 MAÛNG 11.1 Khaùi nieäm 11.2 Khai baùo maûng 11.3 Khôûi ñoäng trò cuûa maûng 11.4 Maûng laø ñoái soá cuûa haøm maûng laø bieán toaøn cuïc 11.5 Caùc öùng duïng Baøi taäp cuoái chöông HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.1 KHAÙI NIEÄM Maûng laø moät bieán caáu truùc trong ñoù coù nhieàu phaàn töû cuøng kieåu, moãi phaàn töû laø moät bieán thaønh phaàn cuûa maûng. Moãi bieán thaønh phaàn naøy laø moät bieán bình thöôøng vaø coù cöôùc soá (subscript) ñeå phaân bieät giöõa phaàn töû naøy vaø phaàn töû kia. Nhö vaäy, ñeå truy xuaát moät phaàn töû cuûa maûng, ta caàn bieát ñöôïc cöôùc soá cuûa noù. Trong boä nhôù, caùc phaàn töû cuûa maûng ñöôïc caáp phaùt oâ nhôù coù ñòa chæ lieân tieáp nhau. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.1 KHAÙI NIEÄM C cuõng cho pheùp laäp trình vieân khai baùo vaø laøm vieäc treân maûng moät chieàu (singledimensional array) vaø maûng nhieàu chieàu (multidimensional array). Soá phaàn töû treân moät chieàu ñöôïc goïi laø kích thöôùc cuûa chieàu ñoù. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.2 KHAI BAÙO MAÛNG 1- Maûng moät chieàu Cuù phaùp khai baùo maûng moät chieàu nhö sau: kieåu teân_maûng [kích_thöôùc]; Vôùi kích_thöôùc laø moät haèng soá nguyeân cuï theå, cho bieát soá phaàn töû trong chieàu ñang xeùt. Trong C, cöôùc soá caùc phaàn töû cuûa maûng luoân ñi töø 0 trôû ñi, neân maûng moät chieàu coù n phaàn töû thì cöôùc soá caùc phaàn töû cuûa maûng laø 0,..., n-1. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.2 KHAI BAÙO MAÛNG 1- Maûng moät chieàu Ví duï : int a[100]; Nhö vaäy maûng a coù 100 phaàn töû int, caùc phaàn töû ñoù laø a[0], a[1],...,a[99]. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.2 KHAI BAÙO MAÛNG 1- Maûng moät chieàu Ví duï : Vieát chöông trình nhaäp moät daõy caùc soá nguyeân, tìm soá lôùn nhaát trong daõy soá ñoù. #include #include main() { int i, n, max, vtmax; int a[100]; clrscr(); HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.2 KHAI BAÙO MAÛNG printf ("Chuong trinh thu mang \n"); printf ("Moi ban nhap so phan tu cua mang: "); scanf ("%d", &n); printf ("Moi nhap cac phan tu cua mang:"); for (i = 0; i < n; i++) scanf ("%d", &a[i]); max = a[0]; vtmax = 0; for (i = 1; i < n; i++) if (max < a[i]) { max = a[i]; vtmax = i; } printf ("Phan tu %d co tri lon nhat la %d\n", vtmax, max); getch() } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.2 KHAI BAÙO MAÛNG 2- Maûng nhieàu chieàu Cuù phaùp khai baùo maûng nhieàu chieàu nhö sau: kieåu teân_maûng [kích_thöôùc_chieàu1] [kích_thöôùc_chieàu2] [...]; Khi dòch C baùo loãi Array size too large ? HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.2 KHAI BAÙO MAÛNG 2- Maûng nhieàu chieàu Ví duï: Khai baùo maûng hai chieàu a int a[4][3]; Nhö vaäy maûng a coù 4x3 phaàn töû int, caùc phaàn töû ñoù laø a[0][0] a[0][1] a[0][2] a[1][0] a[1][1] a[1][2] a[2][0] a[2][1] a[2][2] a[3][0] a[3][1] a[3][2] HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.2 KHAI BAÙO MAÛNG 2- Maûng nhieàu chieàu Caùc phaàn töû naøy ñöôïc saép trong boä nhôù theo thöù töï a[0][0], a[0][1], a[0][2], a[1][0], a[1][1], a[1][2], a[2][0], a[2][1], a[2][2],.... HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.2 KHAI BAÙO MAÛNG 2- Maûng nhieàu chieàu Ví duï: Vieát chöông trình taïo vaø in ra maøn hình ma traän coù daïng sau: 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.2 KHAI BAÙO MAÛNG 2- Maûng nhieàu chieàu #include #include #define MAX 20 main() { int i, j; int a[MAX][MAX]; int n; clrscr(); printf ("Chuong trinh thu mang \n"); printf ("Moi ban nhap cap cua ma tran: "); HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.2 KHAI BAÙO MAÛNG 2- Maûng nhieàu chieàu scanf ("%d", &n); for (i = 0; i < n; i++) for (j = 0; j < n; j++) if (i == j) a[i][i] = 1; else a[i][j] = 0; printf ("Ma tran duoc tao la: \n"); for (i = 0; i < n; i++) { for (j = 0; j < n; j++) printf ("%d", a[i][j]); getch () } } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.2 KHAI BAÙO MAÛNG 2- Maûng nhieàu chieàu Ví duï : Coù khai baùo int a[10]; maø ta laïi thöïc hieän leänh for (i = 0; i<= 10; i++) a[i] = i; thì trong thöïc teá khoâng coù phaàn töû a[10], nhöng vieäc gaùn cuõng ñöôïc thöïc hieän, vaø oâ nhôù keá tieáp phaàn töû a[9] ñöôïc gaùn trò. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.2 KHAI BAÙO MAÛNG 2- Maûng nhieàu chieàu C khoâng coù söï phaân bieät giöõa moät bieán chuoãi vaø moät maûng caùc kyù töï. Caû hai tröôøng hôïp ñeàu ñöôïc khai baùo char teân [chieàu_daøi]; Ñieåm khaùc bieät? HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.2 KHAI BAÙO MAÛNG 2- Maûng nhieàu chieàu Haøm gets() cho pheùp nhaäp moät chuoãi coù teân ñeå trong ñoái soá haøm naøy. Ví duï : char s[20]; gets (s); HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.2 KHAI BAÙO MAÛNG 2- Maûng nhieàu chieàu Haøm puts() cho pheùp xuaát moät chuoãi coù teân ñeå trong ñoái soá haøm naøy ra maøn hình. Ví duï : char s[20]; puts (s); Caû hai gets() vaø puts() ñeàu coù prototype naèm trong file stdio.h. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.2 KHAI BAÙO MAÛNG 2- Maûng nhieàu chieàu Ví duï : Chöông trình truy xuaát chuoãi duøng haøm chuaån cuûa C. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.2 KHAI BAÙO MAÛNG 2- Maûng nhieàu chieàu #include #include main() { char s[100]; clrscr(); printf ("Moi nhap mot chuoi: "); gets (s); printf ("Chuoi da nhap la: "); puts (s); getch(); } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.3 KHÔÛI ÑOÄNG TRÒ CUÛA MAÛNG Khi khai baùo maûng laø bieán toaøn cuïc hoaëc tónh thì maûng coù theå ñöôïc khôûi ñoäng trò baèng caùc giaù trò haèng. Ví duï : int a[5] = {1, 3, 5, 7, 9}; int b[10] = {1, 2, 3, 4, 5}; Neáu soá trò ít hôn soá phaàn töû maûng thì caùc phaàn töû coøn laïi khoâng ñöôïc khôûi ñoäng trò, coù nghóa caùc phaàn töû naøy coù trò laø 0. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.3 KHÔÛI ÑOÄNG TRÒ CUÛA MAÛNG Ví duï: double a[] = {1.23, –5.67, 9.87, 1.34}; char s[30] = “I go to shool \n”; char ch[] = “Hello, World!”; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.3 KHÔÛI ÑOÄNG TRÒ CUÛA MAÛNG Ví duï : Chuoãi char s[] = “Hello”; char ch[] = {'H', 'e', 'l', 'l', 'o'}; H e l l o \0 H e l l o HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.4 MAÛNG LAØ ÑOÁI SOÁ CUÛA HAØM MAÛNG LAØ BIEÁN TOAØN CUÏC Khi khai baùo ñoái soá cuûa haøm laø maûng, thì kích thöôùc cuûa chieàu ñaàu tieân cuûa maûng khoâng caàn xaùc ñònh cuï theå. Tuy nhieân töø chieàu thöù hai trôû ñi, kích thöôùc maûng phaûi xaùc ñònh. Teân maûng chính laø ñòa chæ cuûa maûng, neân vieäc truyeàn teân maûng cho haøm chính laø truyeàn ñòa chæ thöïc cuûa maûng neân moïi thay ñoåi treân maûng trong haøm cuõng chính laø thay ñoåi treân maûng thaät (truyeàn theo kieåu tham soá bieán). HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.4 MAÛNG LAØ ÑOÁI SOÁ CUÛA HAØM MAÛNG LAØ BIEÁN TOAØN CUÏC Ví duï 5.14 (SGT) void select_sort (int a[ ], int n) { .... } Ví duï 5.15 (SGT) HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.5 CAÙC ÖÙNG DUÏNG 11.5.1 Saép xeáp maûng Trong phaàn treân, ñeå saép xeáp moät maûng, giaûi thuaät ñöôïc neâu ra laø giaûi thuaät select sort, trong muïc naøy ta seõ xeùt theâm hai giaûi thuaät nöõa laø giaûi thuaät bubble sort vaø quick sort. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.5 CAÙC ÖÙNG DUÏNG 11.5.1 Saép xeáp maûng 1- Bubble sort (ví duï 5.17) Giaûi thuaät sort naøy döïa vaøo nguyeân taéc: phaàn töû nhoû hôn seõ "nheï hôn" vaø vì vaäy seõ "noåi" leân treân. Nhö vaäy, ñaây laø phöông phaùp so saùnh tröïc tieáp hai phaàn töû trong maûng vôùi nhau, neáu phaàn töû naøo nhoû seõ ñöôïc ñoåi choã sang choã coù chæ soá (cöôùc soá) thaáp hôn (neáu vieäc saép xeáp theo thöù töï töø nhoû tôùi lôùn). HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.5 CAÙC ÖÙNG DUÏNG 11.5.1 Saép xeáp maûng 1- Bubble sort (ví duï 5.17) Chuong trinh thu ma tran Moi ban nhap kich thuoc day: 5 Moi nhap cac phan tu cua ma tran: 9 -5 7 0 1 Lan lap thu 0 9 -5 0 7 1 -5 9 0 7 1 Lan lap thu 1 -5 9 0 1 7 -5 0 9 1 7 HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.5 CAÙC ÖÙNG DUÏNG 11.5.1 Saép xeáp maûng 1- Bubble sort (ví duï 5.17) Lan lap thu 2 -5 0 1 9 7 Lan lap thu 3 -5 0 1 7 9 Ma tran duoc sap xep la: -5 0 1 7 9 HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.5 CAÙC ÖÙNG DUÏNG 11.5.1 Saép xeáp maûng 2- Quick sort Ñaây laø giaûi thuaät sort ñöôïc ñaùnh giaù laø nhanh nhaát trong caùc giaûi thuaät saép xeáp. Nguyeân taéc cuûa giaûi thuaät naøy nhö sau: Giaûi thuaät quick sort baét ñaàu baèng vieäc tìm moät giaù trò giöõa taàm cho maûng. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.5 CAÙC ÖÙNG DUÏNG 11.5.1 Saép xeáp maûng 2- Quick sort Giaù trò giöõa taàm coù theå ñöôïc tính baèng trung bình coäng cuûa hai phaàn töû ñaàu tieân vaø sau cuøng trong phaàn maûng ñang ñöôïc saép xeáp. Giaûi thuaät seõ chuyeån taát caû caùc phaàn töû coù giaù trò nhoû hôn giaù trò giöõa taàm sang phaàn coù chæ soá thaáp cuûa maûng, vaø chuyeån taát caû caùc phaàn töû coù giaù trò lôùn hôn giaù trò giöõa taàm sang phaàn coù chæ soá cao cuûa maûng. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 86 3 10 23 12 67 59 47 31 24 Trò giöõa taàm Vò trí trong maûng 0 1 2 3 4 5 6 7 8 9 Böôùc 1: 55 86 3 10 23 12 67 59 47 31 24 Böôùc 2: 35 24 3 10 23 12 31 47 59 67 86 Böôùc 3: 27 24 3 10 23 12 31 47 59 67 86 Böôùc 4: 18 24 3 10 23 12 31 47 59 67 86 Böôùc 5: 11 12 3 10 23 24 31 47 59 67 86 Böôùc 6: 6 10 3 12 23 24 31 47 59 67 86 Böôùc 7: 23 3 10 12 23 24 31 47 59 67 86 Böôùc 8: 72 3 10 12 23 24 31 47 59 67 86 Böôùc 9: 63 3 10 12 23 24 31 47 59 67 86 Böôùc 10: 63 3 10 12 23 24 31 47 59 67 86 HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.5 CAÙC ÖÙNG DUÏNG 11.5.1 Saép xeáp maûng 3- Select sort Giaûi thuaät seõ tìm giaù trò lôùn nhaát ñöa veà vò trí coù cöôùc soá thaát nhaát, sau ñoù tìm giaù trò lôùn thöù nhì ñöa veà vò trí coù cöôùc soá thaát nhì, quaù trình dieãn ra töông töï cho ñeán heát Ví duï 8.14(SGT) HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.5 CAÙC ÖÙNG DUÏNG 11.5.2 Stack Stack (taïm dòch laø ngaên xeáp) laø moät kieåu caáu truùc döõ lieäu do laäp trình vieân töï laäp ra, khi caàn, laäp trình vieân coù theå theâm moät phaàn töû vaøo stack, hoaëc xoùa moät phaàn töû ra khoûi stack. Ñaëc ñieåm cuûa caáu truùc döõ lieäu naøy laø döõ lieäu ñöôïc ghi vaøo hoaëc laáy ra khoûi stack theo traät töï vaøo tröôùc ra sau (last-in first-out). HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.5 CAÙC ÖÙNG DUÏNG 11.5.2 Stack Caùc thao taùc caàn coù ñeå laøm vieäc treân stack: - Khôûi ñoäng stack, töông öùng vôùi haøm init_stack() caàn thieát keá. - Caùc haøm ñeå xem stack roãng, ñaày, hay xem trò treân ñænh stack. - Ñaåy moät phaàn töû vaøo stack, töông öùng haøm push() caàn thieát keá. - Laáy moät phaàn töû töø ñænh stack ra, töông öùng vôùi haøm pop() caàn thieát keá. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.5 CAÙC ÖÙNG DUÏNG 11.5.2 Stack Ví duï: HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.5 CAÙC ÖÙNG DUÏNG 11.5.2 Stack Chöông trình öùng duïng stack (SGT) HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.5 CAÙC ÖÙNG DUÏNG 11.5.3 Queue Queue laø moät caáu truùc döõ lieäu, trong ñoù vieäc theâm döõ lieäu vaøo ñöôïc thöïc hieän ôû moät ñaàu, coøn vieäc laáy moät phaàn töû ra khoûi queue ñöôïc thöïc hieän ôû ñaàu kia. Döõ lieäu vaøo ra queue theo traät töï vaøo ñaàu tieân ra ñaàu tieân (first-in first-out). HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.5 CAÙC ÖÙNG DUÏNG 11.5.3 Queue Cuõng töông töï nhö ñoái vôùi stack, caùc thao taùc caàn coù ñeå laøm vieäc treân queue: - Khôûi ñoäng queue, töông öùng vôùi haøm init_queue() caàn thieát keá. - Caùc haøm ñeå xem queue roãng, ñaày. - Theâm moät phaàn töû vaøo queue, töông öùng haøm addqueue() caàn thieát keá. - Laáy moät phaàn töû ra khoûi queue, töông öùng vôùi haøm deletequeue() caàn thieát keá. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.5 CAÙC ÖÙNG DUÏNG 11.5.3 Queue Ví duï: HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 11.5 CAÙC ÖÙNG DUÏNG 11.5.3 Queue Ví du (SGT) HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C BAØI TAÄP CUOÁI CHÖÔNG 1. Nhaäp moät ma traän n x n baát kyø, saép xeáp laïi ma traän sao cho caùc trò lôùn nhaát treân töøng haøng, naèm treân ñöôøng cheùo cuûa ma traän. 2. Vieát chöông trình taïo vaø in ra maøn hình ma traän coù daïng sau: a b c d b c d a c d a b n : tham soá nhaäp d a b c n HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C BAØI TAÄP CUOÁI CHÖÔNG 3. Nhaäp moät chuoãi baát kyø töø baøn phím, xoùa taát caû caùc kyù töï khoaûng traéng thöøa cuûa chuoãi vaø in ra maøn hình chuoãi môùi. 4. Nhaäp moät daõy soá töø baøn phím. Vieát hai haøm ñeå in ra maøn hình bieåu ñoà ngang vaø bieåu ñoà doïc cuûa caùc daáu * töông öùng vôùi caùc soá nhaäp trong daõy soá. Ví duï: Nhaäp 2 4 3; * * * * * * * * * * * * * * * * * * HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C BAØI TAÄP CUOÁI CHÖÔNG 5. Vieát chöông trình taïo vaø in ra maøn hình tam giaùc PASCAL caáp n, vôùi n nhaäp töø baøn phím. 6. Vieát chöông trình taïo ma traän nghòch ñaûo n x n. 7. Vieát chöông trình giaûi heä phöông trình tuyeán tính baèng phöông phaùp Gauss. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C BAØI TAÄP CUOÁI CHÖÔNG 8. Nhaäp moät ma traän vuoâng baát kyø, tính toång caùc haøng, caùc coät, caùc ñöôøng cheùo. 9. Nhaäp moät ma traän baát kyø. In ra maøn hình caùc trò vaø vò trí cuûa caùc soá nguyeân toá coù trong maûng ñoù. 10. Vieát caùc haøm ñoåi töø soá sang chuoãi, vaø töø chuoãi sang soá. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C KEÁT THUÙC CHÖÔNG 11 HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C CHÖÔNG 12 POINTER HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C CHÖÔNG 12 POINTER HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.1 KHAÙI NIEÄM Trong ngoân ngöõ C, moãi bieán vaø chuoãi kyù töï ñeàu ñöôïc löu tröõ trong boä nhôù vaø coù ñòa chæ rieâng, ñòa chæ naøy xaùc ñònh vò trí cuûa chuùng trong boä nhôù. Khi laäp trình trong C, nhieàu luùc chuùng ta caàn laøm vieäc vôùi caùc ñòa chæ naøy, vaø C uûng hoä ñieàu ñoù khi ñöa ra kieåu döõ lieäu pointer (taïm dòch laø con troû) ñeå khai baùo cho caùc bieán löu ñòa chæ. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.1 KHAÙI NIEÄM Moät bieán coù kieåu pointer coù theå löu ñöôïc döõ lieäu trong noù, laø ñòa chæ cuûa moät ñoái töôïng ñang khaûo saùt. Ñoái töôïng ñoù coù theå laø moät bieán, moät chuoãi hoaëc moät haøm. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.1 Khai baùo bieán pointer - pointer haèng Trong ngoân ngöõ C coù moät toaùn töû laáy ñòa chæ cuûa moät bieán ñang laøm vieäc, toaùn töû naøy laø moät daáu & (ampersand), taïm goïi laø toaùn töû laáy ñòa chæ. Cuù phaùp nhö sau: & bieán vôùi bieán laø moät bieán thuoäc kieåu baát kyø, nhöng khoâng ñöôïc laø bieán thanh ghi. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.1 Khai baùo bieán pointer - pointer haèng Ví duï: Neáu coù moät bieán ñaõ ñöôïc khai baùo laø int heä_soá_a; thì & heä_soá_a seõ laø ñòa chæ cuûa bieán heä_soá_a. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.1 Khai baùo bieán pointer - pointer haèng Cuù phaùp ñeå khai baùo bieán pointer: kieåu * teân_bieán_pointer vôùi - kieåu coù theå laø kieåu baát kyø, xaùc ñònh kieåu döõ lieäu coù theå ñöôïc ghi vaøo ñoái töôïng maø con troû ñang troû ñeán. - teân_bieán_pointer laø teân cuûa bieán con troû, moät danh hieäu hôïp leä. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.1 Khai baùo bieán pointer - pointer haèng Bieán hoaëc ñoái töôïng maø con troû ñang troû ñeán coù theå ñöôïc truy xuaát qua teân cuûa bieán con troû vaø daáu "*" ñi ngay tröôùc bieán con troû, cuù phaùp cuï theå nhö sau: * teân_bieán_con_troû HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.1 Khai baùo bieán pointer - pointer haèng Ví duï: Xeùt caùc khai baùo sau: int a, b; int *pa; Sau khi khai baùo, ta coù ba oâ nhôù cho ba bieán a, b vaø pa nhö sau: HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.1 Khai baùo bieán pointer - pointer haèng Ví duï: void * pvoid; int a, * pint; double b, * pdouble; pvoid = (void *) &a; pint = (int *) pvoid; (*pint) ++; pvoid = (void *) &b; pdouble = (double *) pvoid; (*pdouble) -- ; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.2 Caùc pheùp toaùn treân pointer Coù theå coäng, tröø moät pointer vôùi moät soá nguyeân (int, long,...). Keát quaû laø moät pointer. Ví duï : int *pi1, *pi2, n; pi1 = &n; pi2 = pi1 + 3; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.2 Caùc pheùp toaùn treân pointer Ví duï: Cho khai baùo int a[20]; int *p; p = &a[0]; p += 3; /* p löu ñòa chæ phaàn töû a[0 + 3], töùc &a[3] */ HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.2 Caùc pheùp toaùn treân pointer Khoâng theå thöïc hieän caùc pheùp toaùn nhaân, chia, hoaëc laáy dö moät pointer vôùi moät soá, vì pointer löu ñòa chæ, neân neáu thöïc hieän ñöôïc ñieàu naøy cuõng khoâng coù moät yù nghóa naøo caû. Pheùp tröø giöõa hai pointer vaãn laø moät pheùp toaùn hôïp leä, keát quaû laø moät trò thuoäc kieåu int bieåu thò khoaûng caùch (soá phaàn töû) giöõa hai pointer ñoù. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.2 Caùc pheùp toaùn treân pointer Ví duï: Xeùt chöông trình ví duï sau: #include #include main() { int *p1, *p2; int a[10]; clrscr(); p1 = &a[0]; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.2 Caùc pheùp toaùn treân pointer Ví duï: p2 = &a[5]; printf ("Dia chi cua bien a[0] la: %p\n", p1); printf ("Dia chi cua bien a[5] la: %p\n", p2); printf ("Khoang cach giua hai phan tu la %d int\n", p2 - p1); getch(); } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.2 Caùc pheùp toaùn treân pointer Chöông trình seõ cho xuaát lieäu ví duï: Dia chi cua bien a[0] la: FFE2 Dia chi cua bien a[5] la: FFEC Khoang cach giua hai phan tu la 5 int HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.2 Caùc pheùp toaùn treân pointer Ví duï: Cho caùc khai baùo sau: int * a1; char * a2; a1 = 0; /* Chöông trình dòch seõ nhaéc nhôû leänh naøy */ a2 = (char *)0; if( a1 != a2) /* Chöông trình dòch seõ nhaéc nhôû kieåu cuûa ñoái töôïng */ { a1 = (int *) a2; /* Hôïp leä vì ñaõ eùp kieåu */ } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.2 Caùc pheùp toaùn treân pointer Ví duï: #include #include main() { int *pint, a = 0 6141; char *pchar; clrscr(); pint = &a; pchar = (char *) &a; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.2 Caùc pheùp toaùn treân pointer Ví duï: printf ("Tri cua bien pint la: %p\n", pint); printf ("Tri cua bien pchar la: %p\n", pchar); printf ("Doi tuong pint dang quan ly la %X \n", *pint); printf ("Doi tuong pchar dang quan ly la %c \n", *pchar); pchar++; printf ("Doi tuong pchar dang quan ly la %c \n", *pchar); getch(); } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.2 Caùc pheùp toaùn treân pointer Chöông trình cho xuaát lieäu ví duï: Tri cua bien pint la: FFF4 Tri cua bien pchar la: FFF4 Doi tuong pint dang quan ly la 6141 Doi tuong pchar dang quan ly la A Doi tuong pchar dang quan ly la a HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.2 Caùc pheùp toaùn treân pointer C cho pheùp khai baùo moät bieán pointer laø haèng hoaëc ñoái töôïng cuûa moät pointer laø haèng. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.2 Caùc pheùp toaùn treân pointer Caùc khai baùo sau ñaây laø bieán pointer haèng: 1. int a, b; int * const pint = &a; pint = &b;  C baùo loãi 2. char * const ps = "ABCD"; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.2 Caùc pheùp toaùn treân pointer Caùc khai baùo sau ñaây cho thaáy ñoái töôïng cuûa moät pointer laø haèng: 1. int i; const int * pint; pint = &i; i = 1; (*pint) ++; C baùo loãi i++; 2. const char * s = "ABCD" hoaëc char const * s = "ABCD"; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.2 THAO TAÙC TREÂN POINTER 12.2.2 Caùc pheùp toaùn treân pointer Phaân bieät: const tröôùc * : pointer chæ ñeán ñoái töôïng haèng * tröôùc const : pointer haèng HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.3 POINTER VAØ MAÛNG Coù moät söï töông quan chaët cheû giöõa maûng vaø pointer, vì trong C, teân maûng laø moät haèng pointer, noù chính laø ñòa chæ cuûa phaàn töû ñaàu tieân cuûa maûng. Ví duï: Cho khai baùo sau: int a[10]; int *pa; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.3 POINTER VAØ MAÛNG *(a + 0) chính laø a[0], *(a + 1) chính laø a[1], .... *(a + i) chính laø a[i]. Coù theå gaùn: pa = a; hoaëc pa =&a[0]; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.3 POINTER VAØ MAÛNG Khi ñoù, (pa + 0) seõ chæ ñeán phaàn töû a[0], (pa + 1) seõ chæ ñeán phaàn töû a[1], ... (pa + i) seõ chæ ñeán phaàn töû a[i]. Nhö vaäy, caùc ñoái töôïng *(pa + 0) chính laø *(a + 0), cuõng laø a[0] *(pa + 1) chính laø *(a + 1), cuõng laø a[1] ... *(pa + i) chính laø *(a + i), cuõng laø a[i] HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.3 POINTER VAØ MAÛNG Coù theå truy suaát ñeán caùc ñoái töôïng cuûa maûng maø pointer ñang troû ñeán nhö sau: pa[0] chính laø phaàn töû a[0] pa[1] chính laø phaàn töû a[1] ... pa[i] chính laø phaàn töû a[i]. Ví duï 6.15 (SGT) HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.3 POINTER VAØ MAÛNG Phaân bieät roõ raøng giöõa maûng vaø pointer. -Moät maûng, sau khi ñöôïc khai baùo vaø ñònh nghóa, ñaõ ñöôïc caáp moät vuøng nhôù trong boä nhôù trong cuûa maùy tính vaø ñòa chæ chính laø teân maûng. -Moät bieán pointer, sau khi ñöôïc khai baùo, thì vuøng nhôù ñöôïc caáp chæ laø baûn thaân bieán pointer, coøn trò beân trong noù laø moät ñòa chæ raùc. -Ngoaøi ra, bieán pointer coù moät ñòa chæ trong boä nhôù, coøn khoâng theå laáy ñòa chæ cuûa teân maûng. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.3 POINTER VAØ MAÛNG Ví duï: Sau khi khai baùo int a[10]; thì trong boä nhôù, a laø moät haèng pointer, hay moät ñòa chæ coá ñònh Caùc phaàn töû trong maûng ñang coù trò raùc. Vì teân maûng laø moät haèng pointer a++; laø khoâng hôïp leä. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.3 POINTER VAØ MAÛNG Ví duï: int *pa; thì trong boä nhôù do ñoù leänh gaùn *pa = 2; laø khoâng coù yù nghóa, duø C khoâng baùo loãi trong tröôøng hôïp naøy. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.3 POINTER VAØ MAÛNG Ví duï 6.18 vaø 6.19 (SGT) HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.4 ÑOÁI SOÁ CUÛA HAØM LAØ POINTER - TRUYEÀN ÑOÁI SOÁ THEO SOÁ DAÏNG THAM SOÁ BIEÁN Ví duï: #include #include void hoan_doi (int a, int b); main() { int so1 = 1, so2 = 2; clrscr(); printf ("Tri cua hai bien so1 vaø so2 la: %d %d\n", so1, so2); hoan_doi(so1, so2), HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.4 ÑOÁI SOÁ CUÛA HAØM LAØ POINTER - TRUYEÀN ÑOÁI SOÁ THEO SOÁ DAÏNG THAM SOÁ BIEÁN printf("Sau khi goi ham, tri cua so1 va so2 la: %d %d\n",so1,so2); getch(); } void hoan_doi (int a, int b) { int temp; temp = a; a = b; b = temp; } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.4 ÑOÁI SOÁ CUÛA HAØM LAØ POINTER - TRUYEÀN ÑOÁI SOÁ THEO SOÁ DAÏNG THAM SOÁ BIEÁN Ví duï: #include #include void hoan_doi (int *a, int *b); main () { int so1 = 1, so2 = 2; clrscr(); printf ("Tri cua hai bien so1 va so2 la: %d %d\n", so1, so2); hoan_doi (&so1, &so2); HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.4 ÑOÁI SOÁ CUÛA HAØM LAØ POINTER - TRUYEÀN ÑOÁI SOÁ THEO SOÁ DAÏNG THAM SOÁ BIEÁN printf ("Sau khi goi ham, tri cua so1 va so2 la: %d %d\n", so1, so2); getch(); } void hoan_doi (int *a, int *b) { int temp; temp = *a; *a = *b; *b = temp; } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.4 ÑOÁI SOÁ CUÛA HAØM LAØ POINTER - TRUYEÀN ÑOÁI SOÁ THEO SOÁ DAÏNG THAM SOÁ BIEÁN Trong thö vieän chuaån cuûa C cuõng coù nhieàu haøm nhaän ñoái soá vaøo theo ñòa chæ, ví duï haøm scanf(), nhaäp trò vaøo cho bieán töø baøn phím. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.4 ÑOÁI SOÁ CUÛA HAØM LAØ POINTER - TRUYEÀN ÑOÁI SOÁ THEO SOÁ DAÏNG THAM SOÁ BIEÁN Ví duï: #include #include main() { int n; clrscr(); printf("Moi nhap mot so nguyen "); scanf("%d", &n); printf("\n Binh phuong cua %d la %d\n", n, n*n); getch(); } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.5 HAØM TRAÛ VEÀ POINTER VAØ MAÛNG Moät pointer coù theå ñöôïc traû veà töø haøm, neáu pointer troû ñeán ñoái töôïng laø maûng, thì haøm traû veà maûng; neáu pointer chæ troû ñeán bieán bình thöôøng, thì haøm chæ traû veà con troû troû ñeán bieán thöôøng, cuù phaùp khai baùo haøm nhö sau: kieåu * teân_haøm (danh_saùch_khai_baùo_ñoái_soá); vôùi kieåu laø kieåu cuûa ñoái töôïng maø pointer ñöôïc haøm traû veà troû ñeán. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.5 HAØM TRAÛ VEÀ POINTER VAØ MAÛNG Ví duï: Coù khai baùo int * lon_nhat (int a, int b, int c); thì haøm lon_nhat() traû veà moät ñòa chæ, ñòa chæ ñoù coù theå laø ñòa chæ cuûa moät int hoaëc ñòa chæ cuûa moät maûng caùc int, vieäc söû duïng ñòa chæ theo ñoái töôïng naøo laø do nôi goïi. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.5 HAØM TRAÛ VEÀ POINTER VAØ MAÛNG Ví duï: Thieát keá haøm nhaäp trò cho maûng caùc int int *nhap_tri (int *num) { static int a[10]; int i, n; printf ("Nhap kich thuoc mang:"); scanf ("%d", &n); *num = n; printf ("Nhap tri cho %d phan tu cua mang:", n); for (i = 0; i < n; i++) scanf ("%d", &a[i]); return a; /* a laø ñòa chæ ñaàu maûng caàn traû veà */ } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.5 HAØM TRAÛ VEÀ POINTER VAØ MAÛNG Ví duï: Chöông trình söû duïng haøm nhaäp trò maûng #include #include int *nhap_tri(int *num); main() { int *pint, so_phan_tu, i; clrscr(); pint = nhap_tri (&so_phan_tu); printf ("Cac phan tu cua mang la:"); for (i =0; i <so_phan_tu; i++) printf ("%d", pint[i]); getch(); } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.6 CHUOÃI KYÙ TÖÏ Ví duï: Khi khai baùo “Hello, world!” thì chuoãi naøy seõ ñöôïc C ghi vaøo moät nôi naøo ñoù trong boä nhôù vaø coù ñòa chæ xaùc ñònh. Ñòa chæ naøy coù theå ñöôïc gaùn vaøo cho moät bieán con troû troû ñeán kyù töï ñeå quaûn lyù chuoãi. Ví duï : Cho khai baùo char s[20]; s = “Hello, world!”; Khoâng hôïp leä HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.6 CHUOÃI KYÙ TÖÏ 1- Nhaäp trò chuoãi Vieäc nhaäp trò cho chuoãi bao goàm hai böôùc: ñaàu tieân caàn khai baùo moät nôi troáng ñeå chöùa chuoãi, sau ñoù duøng moät haøm nhaäp trò ñeå laáy chuoãi. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.6 CHUOÃI KYÙ TÖÏ 1- Nhaäp trò chuoãi - Haøm gets() ñoïc caùc kyù töï ñeán khi naøo gaëp kyù töï quy ñònh haøng môùi (töùc kyù töï '\n', töùc khi ta aán phím ENTER) thì keát thuùc vieäc nhaäp. Sau ñoù haøm naøy laáy taát caû caùc kyù töï ñaõ nhaäp tröôùc kyù töï '\n', gaén theâm vaøo cuoái chuoãi moät kyù töï NUL ('\0') vaø traû chuoãi cho chöông trình goïi. Prototype cuûa haøm naøy trong file stdio.h: char * gets (char * s); HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.6 CHUOÃI KYÙ TÖÏ 1- Nhaäp trò chuoãi Ví duï: #include #include main() { char ten[41]; char *pten; clrscr(); printf ("Ban ten gi?\n"); pten = gets (ten); printf("%s? A! Chao ban %s\n", ten, pten); getch(); } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.6 CHUOÃI KYÙ TÖÏ 1- Nhaäp trò chuoãi - Haøm scanf() cuõng cho pheùp nhaäp chuoãi qua ñònh daïng nhaäp %s. Vieäc nhaäp chuoãi seõ keát thuùc khi haøm scanf() gaëp moät trong caùc kyù töï khoaûng traéng, kyù töï tab hay kyù töï xuoáng haøng ñaàu tieân maø noù gaëp. Ñaây chính laø ñieåm khaùc nhau giöõa hai haøm nhaäp chuoãi gets() vaø scanf(). HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.6 CHUOÃI KYÙ TÖÏ 1- Nhaäp trò chuoãi Ví duï: #include #include main() { char ten1[41], ten2[41]; clrscr(); printf(Moi ban nhap hai ten: ); scanf ("%s %s", ten1, ten2); printf("A! Chao hai ban %s va %s \n", ten1, ten2); getch(); } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.6 CHUOÃI KYÙ TÖÏ 2- Xuaát chuoãi Ñeå xuaát chuoãi, hai haøm thöôøng hay ñöôïc duøng laø puts() vaø printf(). - Haøm puts: ta chæ caàn cung caáp cho haøm ñoái soá laø ñòa chæ cuûa chuoãi caàn in. Haøm naøy seõ ñoïc töøng kyù töï cuûa chuoãi vaø in ra maøn hình cho ñeán khi gaëp kyù töï NUL thì in ra maøn hình theâm moät kyù töï xuoáng haøng nöõa. Prototype cuûa haøm naøy nhö sau: int puts (char * s); HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.6 CHUOÃI KYÙ TÖÏ 2- Xuaát chuoãi - Haøm printf () cuõng cho pheùp xuaát chuoãi ra maøn hình neáu ta duøng ñònh daïng xuaát "%s" cho noù. Haøm naøy seõ khoâng töï ñoäng in theâm kyù töï xuoáng haøng môùi nhö haøm puts(). HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.6 CHUOÃI KYÙ TÖÏ 2- Xuaát chuoãi Ví duï: #include #include main() { char ten[41]; clrscr(); printf ("Moi ban nhap ten: "); gets(ten); printf ("A! Chao ban: %s", ten); getch(); } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.6 CHUOÃI KYÙ TÖÏ 3- Gaùn trò cho chuoãi Vieäc gaùn trò cho bieán chuoãi thöïc teá laø vieäc cheùp töøng kyù töï töø haèng chuoãi hoaëc bieán chuoãi ñaõ bieát sang moät bieán chuoãi khaùc. Trong C, thao taùc naøy ñöôïc thöïc hieän nhôø haøm strcpy(), haøm naøy coù prototype trong file string.h nhö sau: char *strcpy(char *dest, const char *src); HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.6 CHUOÃI KYÙ TÖÏ 3- Gaùn trò cho chuoãi Haøm strcpy coù theå ñöôïc moâ taû nhö sau: char *strcpy(char *dest, const char *src) { int i; for (i = 0; (dest[i] = scr[i]) != '\0'; i++) ; return dest; } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.6 CHUOÃI KYÙ TÖÏ 3- Gaùn trò cho chuoãi Ví duï: #include #include #include main() { char ten1[41], ten2[41]; clrscr(); printf("Moi ban nhap ten: "); gets(ten1); strcpy (ten2, ten1); printf("A! Chao ban: %s", ten2); getch(); } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.6 CHUOÃI KYÙ TÖÏ 4- Laáy chieàu daøi chuoãi Trong C, ñeå laáy chieàu daøi chuoãi ta duøng haøm strlen(). Prototype cuûa haøm naøy trong file string.h: size_t strlen(const char *s); vôùi size_t laø moät kieåu nguyeân, C quy ñònh ñaây laø unsigned. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.6 CHUOÃI KYÙ TÖÏ 4- Laáy chieàu daøi chuoãi Ví duï:Xeùt chöông trình nhaäp moät chuoãi, ñoåi caùc kyù töï thöôøng cuûa chuoãi ñoù thaønh kyù töï hoa, in chuoãi ñoù ra laïi maøn hình. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.6 CHUOÃI KYÙ TÖÏ 4- Laáy chieàu daøi chuoãi #include #include #include main() { char ten[41]; int i; clrscr(); printf("Moi ban nhap ten: "); gets(ten); for ( i = 0; i < strlen (ten); i++) if (ten[i] >= 'a' && ten[i] <= 'z') ten[i] -= 32; printf ("A! Chao ban: %s", ten); getch();} HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.6 CHUOÃI KYÙ TÖÏ 5- Noái chuoãi Ñeå noái hai chuoãi laïi, C coù haøm chuaån strcat(). Haøm naøy nhaän hai chuoãi laøm ñoái soá, vaø moät baûn sao cuûa chuoãi thöù hai seõ ñöôïc cheùp noái vaøo cuoái cuûa chuoãi thöù nhaát, ñeå taïo ra chuoãi môùi. Chuoãi thöù hai vaãn khoâng coù gì thay ñoåi. Prototype cuûa haøm naøy trong file string.h: char *strcat(char *dest, const char *src); Ví duï 6.37(SGT) HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.6 CHUOÃI KYÙ TÖÏ 6- So saùnh chuoãi Haøm naøy laø strcmp(), coù prototype trong file string.h: int strcmp(const char *s1, const char*s2); Haøm naøy so saùnh hai chuoãi s1 vaø s2 vaø traû veà moät trò laø: - soá döông neáu s1 > s2 - soá aâm neáu s1 < s2 - soá 0 neáu s1 == s2 HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.6 CHUOÃI KYÙ TÖÏ 6- So saùnh chuoãi Ví duï:Xeùt chöông trình ví duï sau ñaây #include #include #include main() { clrscr(); printf("%d \n", strcmp("QUAN", quan)); printf("%d \n', strcmp("QUAN", "QUAN")); printf("%d \n", strcmp("quan", "QUAN")); printf("%d \n", strcmp("quang, quanG")); printf("%d \n", strcmp("quang, quan")); getch(); } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.6 CHUOÃI KYÙ TÖÏ 6- So saùnh chuoãi Chöông trình cho xuaát lieäu: -32 032 32 103 HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.7 POINTER VAØ VIEÄC ÑÒNH VÒ BOÄ NHÔÙ ÑOÄNG C cho pheùp khai baùo caùc bieán ñoäng, caùc bieán naøy khi caàn thì xin choã, khoâng caàn thì giaûi phoùng vuøng nhôù cho chöông trình söû duïng vaøo muïc ñích khaùc. Caùc bieán ñoäng naøy ñöôïc caáp phaùt trong vuøng nhôù heap, laø vuøng ñaùy boä nhôù (vuøng coøn laïi sau khi ñaõ naïp caùc chöông trình khaùc xong), vaø ñöôïc quaûn lyù bôûi caùc bieán pointer HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.7 POINTER VAØ VIEÄC ÑÒNH VÒ BOÄ NHÔÙ ÑOÄNG Trong C coù hai haøm chuaån ñeå xin caáp phaùt boä nhôù ñoäng malloc() vaø calloc(), caû hai haøm ñeàu coù prototype naèm trong file alloc.h hoaëc stdlib.h nhö sau: void *malloc(size_t size); void *calloc(size_t nitems, size_t size); HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.7 POINTER VAØ VIEÄC ÑÒNH VÒ BOÄ NHÔÙ ÑOÄNG Neáu bieán ñoäng ñöôïc xin, sau khi duøng xong, vuøng nhôù cuûa noù khoâng ñöôïc giaûi phoùng thì noù vaãn chieám choå trong boä nhôù, maëc duø chöông trình ñaõ keát thuùc. C ñöa ra haøm free() ñeå giaûi phoùng khoái boä nhôù ñöôïc xin baèng haøm malloc() hoaëc calloc(). Prototype cuûa haøm free() trong file stdlib.h hoaëc alloc.h nhö sau: void free (void * block); HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.7 POINTER VAØ VIEÄC ÑÒNH VÒ BOÄ NHÔÙ ÑOÄNG Ví duï: Caàn xin moät khoái boä nhôù coù 10 phaàn töû int, ta vieát nhö sau: int *pint; pint = (int *) malloc (10 * siezof (int)); hoaëc pint = (int *) calloc (10, siezof (int)); HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.7 POINTER VAØ VIEÄC ÑÒNH VÒ BOÄ NHÔÙ ÑOÄNG Ví duï: #include #include #include  EXIT #include main() { int *pint, s = 0, i; pint = (int *) calloc (10, sizeof (int)); if (pint == NULL) { printf ("Khong du bo nho \n"); exit (1); } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.7 POINTER VAØ VIEÄC ÑÒNH VÒ BOÄ NHÔÙ ÑOÄNG Ví duï: clrscr(); printf ("Moi nhap 10 tri vao mang: "); for (i = 0; i <10; i++) scanf ("%d", &pint[i]); for (i = 0; i <10; i++) s += pint[i]; printf ("Tong cac phan tu cua mang la: %d \n", s); getch(); free (pint); } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.8 MAÛNG CAÙC POINTER Cuù phaùp khai baùo maûng caùc pointer: kieåu * teân_maûng [Kích_thöôùc]; Ví duï: Khi khai baùo int * pint[4]; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.8 MAÛNG CAÙC POINTER Ví duï: Khi khai baùo int * pint[4]; int a = 2, b = 3, c = 4, d = 5; pint[0] = &a; pint[1] = &b; pint[2] = &c; pint[3] = &d; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.8 MAÛNG CAÙC POINTER HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.8 MAÛNG CAÙC POINTER Ví duï: Khi khai baùo int * pint[4]; int a[3], b[3], c[3], d[3]; pint[0] = a; pint[1] = b; pint[2] = c; pint[3] = d; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.8 MAÛNG CAÙC POINTER HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.8 MAÛNG CAÙC POINTER Ví duï 6.43, 6.44 (SGT) Moät maûng caùc pointer cuõng coù theå ñöôïc khôûi ñoäng trò neáu maûng laø maûng toaøn cuïc hay maûng tónh. Ví duï: static char *thu[7] = {"Thu 2", "Thu 3", "Thu 4", "Thu 5", "Thu 6", "Thu 7", "Chua nhat"}; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.9 POINTER CUÛA POINTER Cuù phaùp khai baùo pointer naøy nhö sau: kieåu ** teân_pointer Ví duï: int **pint; int a[4][4]; thì pint = a; laø moät leänh hôïp leä Thay vì truy xuaát a[i][j], ta coù theå truy xuaát *(pint + m*i + j), vôùi m laø soá phaàn töû treân moät haøng cuûa maûng hai chieàu. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.9 POINTER CUÛA POINTER HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.9 POINTER CUÛA POINTER Ví duï : int *m[4]; int a = 1, b = 2, c = 3, d = 4; int **pint; pint = m; m[0] = &a; m[1] = &b; m[2] = &c; m[3] = &d; Thay vì truy xuaát tröïc tieáp a, b, ..., ta coù theå duøng pointer *(pint[i]) HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.9 POINTER CUÛA POINTER Ví duï: Xeùt khai baùo sau: int ** pi; int * pint[4]; int a[3], b[3], c[3], d[3]; pi = pint; pint[0] = a; pint[1] = b; pint[2] = c; pint[3] = d; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.9 POINTER CUÛA POINTER HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.9 POINTER CUÛA POINTER Ví duï 6.51(SGT) HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.10 ÑOÁI SOÁ CUÛA HAØM MAIN C hoaøn toaøn cho pheùp vieäc nhaän ñoái soá vaøo haøm main(), coù hai ñoái soá C ñaõ quy ñònh theo thöù töï: int agrc: ñoái soá cho bieát soá tham soá ñaõ nhaäp, keå caû teân chöông trình. char *argv[]: maûng caùc pointer troû ñeán caùc chuoãi laø tham soá ñi theo sau teân chöông trình khi chaïy chöông trình töø DOS. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.10 ÑOÁI SOÁ CUÛA HAØM MAIN Ví duï: Xeùt chöông trình ví duï sau: #include #include main (int argc, char *argv[]) { int i; clrscr(); printf ("Cac doi so cua chuong trinh la: \n"); printf ("Ten chuong trinh la: %s \n", argv[0]); if ( argc >1 ) for (i = 1; i < argc; i++) printf ("Doi so thu %d: %s \n", i, argv[i]); getch(); } HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.10 ÑOÁI SOÁ CUÛA HAØM MAIN Neáu nhaäp töø baøn phím nhö sau C:\>thu_main tin thu 123 thì chöông trình cho xuaát lieäu laø: Cac doi so cua chuong trinh la: Ten chuong trinh la: C:\thu_main.exe Doi so thu 1: tinDoi so thu 2: thu Doi so thu 3: 123 Ví duï 6.54(SGT) HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.11 POINTER TROÛ ÑEÁN HAØM Cuù phaùp khai baùo moät pointer chæ tôùi haøm: kieåu (* teân_pointer) (kieåu_caùc_ñoái_soá); Chuù yù: kieåu * teân_haøm (kieåu_caùc_ñoái_soá);Haøm traû veà pointer HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.11 POINTER TROÛ ÑEÁN HAØM Ví duï: Neáu khai baùo int (* p_function) (int, int); vaø ñaõ coù haøm int cong (int a, int b) { ... } p_function = cong; tong = (*p_function) (m, n); HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.11 POINTER TROÛ ÑEÁN HAØM Ví duï 6.57 (SGT) HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 12.12 ÖÙNG DUÏNG 12.12.1 Danh saùch lieân keát laø stack 12.12.2 Danh saùch lieân keát laø queue (SGT) HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C KEÁT THUÙC CHÖÔNG 12 HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C CHÖÔNG 13 CAÙC KIEÅU DÖÕ LIEÄU COÙ CAÁU TRUÙC VAØ KIEÅU DÖÕ LIEÄU TÖÏ ÑÒNH NGHÓA HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C CHÖÔNG 13 CAÙC KIEÅU DÖÕ LIEÄU COÙ CAÁU TRUÙC VAØ KIEÅU DÖÕ LIEÄU TÖÏ ÑÒNH NGHÓA 13.1 Kieåu STRUCT 13.2 Kieåu UNION 13.3 Kieåu ENUM (Enumerated) 13.4 Ñònh nghóa kieåu baèng TYPEDEF Baøi taäp cuoái chöông HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.1 KIEÅU STRUCT 13.1.1 Khaùi nieäm - Khai baùo struct Struct (taïm diïch laø caáu truùc) laø moät kieåu döõ lieäu phöùc hôïp ñöôïc taïo töø caùc kieåu döõ lieäu khaùc, caùc kieåu döõ lieäu naøy ñöôïc söû duïng khai baùo cho caùc bieán thaønh phaàn cuûa bieán kieåu struct. struct teân_caáu_truùc { Khai baùo caùc bieán thaønh phaàn }; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.1 KIEÅU STRUCT 13.1.1 Khaùi nieäm - Khai baùo struct struct sinh_vieân { char ma_so[10]; char ho_ten[40]; int tuoi; char dia_chi[80]; }; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.1 KIEÅU STRUCT 13.1.1 Khaùi nieäm - Khai baùo struct Cuù phaùp cuûa moät khai baùo bieán caáu truùc gioáng nhö khai baùo bieán bình thöôøng: struct teân_struct teân_bieán; Ví duï: struct sinh_vien sv1, sv2; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.1 KIEÅU STRUCT 13.1.1 Khaùi nieäm - Khai baùo struct Ví duï: struct sinh_vieân { char ma_so[10]; char ho_ten[40]; int tuoi; char dia_chi[80]; } sv1, sv2; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.1 KIEÅU STRUCT 13.1.1 Khaùi nieäm - Khai baùo struct 10 byte 40 byte 2 byte 80 byte ma_so ho_ten tuoi dia_chi HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.1 KIEÅU STRUCT 13.1.1 Khaùi nieäm - Khai baùo struct Ví duï: struct sinh_vien sv1 = { "4950897", "Tran van Vinh", 21, "42 Truong Cong Dinh p.13 q.TB"}; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.1 KIEÅU STRUCT 13.1.1 Khaùi nieäm - Khai baùo struct Ñeå truy xuaát moät thaønh phaàn cuûa bieán caáu truùc, C coù toaùn töû chaám “.” ñeå laáy töøng thaønh phaàn. Ví duï: strcpy (sv1.ma_so, 4950897"); strcpy (sv1.ho_ten, Tran van Dinh"); sv1.tuoi = 21; strcpy (sv1.dia_chi, "42 Truong Cong Dinh p.13 q.TB"); HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.1 KIEÅU STRUCT 13.1.1 Khaùi nieäm - Khai baùo struct C cho pheùp gaùn caùc caáu truùc cuøng kieåu cho nhau qua teân bieán caáu truùc thay vì phaûi gaùn töøng thaønh phaàn cho nhau. Ví duï: sv2 = sv1; Ví duï 7.8 (SGT) HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.1 KIEÅU STRUCT 13.1.1 Khaùi nieäm - Khai baùo struct Caùc thaønh phaàn cuûa bieán struct cuõng laø bieán bình thöôøng, neân ta coù theå laáy ñòa chæ cuûa chuùng, ñòa chæ naøy laø moät haèng pointer troû ñeán thaønh phaàn töông öùng. Ví duï 7.9 (SGT) HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.1 KIEÅU STRUCT 13.1.1 Khaùi nieäm - Khai baùo struct Kieåu struct coù theå ñöôïc laáy kích thöôùc tính theo byte nhôø toaùn töû sizeof, ví duï: sizeof (struct sinh_vien); HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.1 KIEÅU STRUCT 13.1.2 Maûng caùc struct Cuù phaùp khai baùo maûng caùc struct: struct ten_cau_truc ten_mang [kich_thuoc]; Ví duï: struct sinh_vien sv[50]; strcpy (sv[0].ho_ten, “Dang thanh Tin”); sv[0].tuoi = 28; Ví duï 7.12(SGT) HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.1 KIEÅU STRUCT 13.1.3 Pointer tôùi moät struct Cuù phaùp khai baùo bieán pointer naøy nhö sau: struct teân_caáu_truùc *teân_pointer; Ví duï : struct sinh_vien a, *psv; psv =&a; hoaëc struct sinh_vien sv[20], *psv; psv =sv; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.1 KIEÅU STRUCT 13.1.3 Pointer tôùi moät struct Vieäc truy xuaát ñeán moät thaønh phaàn cuûa moät caáu truùc thoâng qua moät pointer ñöôïc thöïc hieän baèng toaùn töû laáy thaønh phaàn cuûa ñoái töôïng cuûa pointer, kyù hieäu laø -> (coù theå goïi laø toaùn töû muõi teân). Ví duï: printf ("Ho ten sinh vien: %s \n", psv -> ho_ten); hay printf ("Ho ten sinh vien: %s \n", (*psv).ho_ten); HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.1 KIEÅU STRUCT 13.1.3 Pointer tôùi moät struct Ví duï 7.16 (SGT) C laïi cho pheùp khai baùo struct maø trong caùc thaønh phaàn cuûa noù laïi coù caùc pointer chæ ñeán moät caáu truùc cuøng kieåu. Ví duï: struct node { char message[81]; struct node * }; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.1 KIEÅU STRUCT 13.1.4 Struct daïng field C cho pheùp ta khai baùo caùc thaønh phaàn cuûa struct theo bit hoaëc moät nhoùm bit. Moät thaønh phaàn nhö vaäy ñöôïc goïi laø moät field (taïm dòch laø vuøng). struct teân_caáu_truùc { kieåu teân_vuøng 1: soá_bit1; kieåu teân_vuøng 2:soá_bit2; ... } teân_bieán; Vôùi kieåu chæ coù theå laø unsigned, signed hoaëc int HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.1 KIEÅU STRUCT 13.1.4 Struct daïng field Ví duï: struct date { unsigned day: 5; unsigned month: 4; unsigned year: 6; int: 0; } ngay; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.1 KIEÅU STRUCT 13.1.4 Struct daïng field Chuù yù: -Moãi vuøng chæ coù theå daøi toái ña 16 bit (moät int) vaø ñöôïc caáp choã trong moät int, chöù khoâng theå naèm treân hai int khaùc nhau ñöôïc. -Söï phaân boá bit cho caùc field trong moät int cuûa struct (töø traùi sang phaûi hay ngöôïc laïi), khoâng phaân bieät ñöôïc. -Moïi thao taùc thöïc hieän treân bieán kieåu field coù lieân quan ñeán ñòa chæ ñeàu khoâng ñöôïc thöïc hieän HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.1 KIEÅU STRUCT 13.1.4 Struct daïng field Ví duï: Khi khai baùo struct vi_du { unsigned field1: 7; unsigned field2: 5; unsigned field3: 2; unsigned field4: 6; unsigned field5: 7; } vd; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.1 KIEÅU STRUCT 13.1.4 Struct daïng field Ví duï: HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.2 KIEÅU UNION Trong ngoân ngöõ C coù kieåu döõ lieäu union (taïm dòch laø kieåu hôïp nhaát), ñaây laø moät kieåu döõ lieäu ñaëc bieät maø neáu ñöôïc khai baùo thì öùng vôùi moät vuøng nhôù, giaù trò ôû moãi thôøi ñieåm khaùc nhau thì coù theå coù kieåu khaùc nhau tuøy vaøo vieäc söû duïng bieán thaønh phaàn trong noù. HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.2 KIEÅU UNION Ví duï: Coù khai baùo union nhö sau: union thu { char c; int i; float f; double d; }; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.2 KIEÅU UNION Khai baùo bieán kieåu union: union teân_union { khai_baùo_bieán_thaønh_phaàn } bieán, bieán [,...]; hoaëc union teân_union bieán, bieán [...]; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.2 KIEÅU UNION Ví duï: union thu { char c; int i; float f; double d; } a, b; hoaëc union thu a, b; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.2 KIEÅU UNION Ñeå truy xuaát ñeán moät bieán thaønh phaàn cuûa bieán thuoäc kieåu uinion, ta cuõng duøng toaùn töû chaám “.”. Ví duï: unoin thu a; a.c = 'a'; Ta coù theå khai baùo moät bieán pointer chæ ñeán moät bieán kieåu union. Ví duï: union thu *pthu, a; pthu = &a; HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.2 KIEÅU UNION Vieäc truy xuaát ñeán moät thaønh phaàn cuûa union qua pointer cuõng ñöôïc thöïc hieän baèng toaùn töû muõi teân, ñeå laáy thaønh phaàn cuûa union ñang ñöôïc pointer chæ ñeán. Ví duï: pthu->c = 'A'; Ví duï 7.30 (SGT) Kieåu union coù theå ñöôïc laáy kích thöôùc tính theo byte qua toaùn töû sizeof, ví duï: sizeof (union thu); HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C 13.3 KIEÅU ENUM (ENUMERATED) 13.4 ÑÒNH NGHÓA KIEÅU BAÈNG TYPEDEF HEÄ THOÁNG MAÙY TÍNH VAØ NGOÂN NGÖÕ C KEÁT THUÙC CHÖÔNG 13

Các file đính kèm theo tài liệu này:

  • pdfHệ thống máy tính và ngôn ngữ C.pdf
Tài liệu liên quan