1. Trang chủ
  2. » Công Nghệ Thông Tin

Bài giảng Nhập môn lập trình: Mở đầu - Trần Phước Tuấn

22 6 0

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Định dạng
Số trang 22
Dung lượng 295,3 KB

Nội dung

Bài giảng Nhập môn lập trình phần mở đầu giới thiệu cho người học một số nội dung như: Các thành phần trong chương trình C, kiểu dữ liệu cơ sở trong C, toán tử trong C,...và một số nội dung khác. Mời các bạn cùng tham khảo.

NMLT M U Tr n Ph c Tu n tranphuoctuan.khoatoan.dhsp@gmail.com http://baigiang.tranphuoctuan.com ng gi ng M c tiêu môn h c: Cung c p cho sinh viên k ng c b n l p trình gi i quy t v n , tốn Các ch ng trình c th hi n b ng NNLT C Riêng v ngơn ng l p trình C, sinh viên c cung c p k ng: c vi t c ch ng trình n gi n Hi u c u trúc ngôn ng S d ng thành th o th vi n chu n Nh n bi t s a ch a l i th ng g p l p trình Các mơn h c tiên quy t: không N i dung gi ng: NH P MƠN L P TRÌNH 12/23/2009 N i dung môn h c T ng quan Các ki u d li u c b n L nh nh p, xu t d li u Các c u trúc i u n Hà m Struct M ng Con tr Chu i ký t NH P MƠN L P TRÌNH 12/23/2009 T ng quan Khái ni m ch ng trình – l p trình C u trúc m t ch ng trình n gi n Khái ni m Thu t toán – bi u di n thu t toán Khái ni m NNLT, l c l ch s phát tri n NNLT Ngơn ng l p trình C NH P MƠN L P TRÌNH 12/23/2009 Các thành ph n c a ch ng trình C Ví d ch ng trình C Th Ghi chú vi n nh p xu t chu n /*VIDU.CPP*/ /*VIDU.CPP*/ #include #include Hàm main int int main() main() {{ printf(“Nhap printf(“Nhap mon mon lap lap trinh\n"); trinh\n"); printf(“Vi du don gian\n"); printf(“Vi du don gian\n"); return return 0; 0; }} Nhap Nhap mon mon lap lap trinh trinh Vi du don gian Vi du don gian Báo CT k t thúc cho H H NH P MƠN L P TRÌNH 12/23/2009 M ts Ph n ghi u ý t ví d c trình biên d ch b qua Phân bi t ch in hoa ch in th ng Câu l nh c k t thúc b ng d u ; Chu i ký t ph i ghi gi a c p nháy kép “ In xu ng dịng dùng ký t \n Ch ng trì trình nên thông bá báo k t qu th c hi n v i h th ng: T t – 0, có l i – 1, 2, … Ch ng trình có m t hàm main NH P MƠN L P TRÌNH 12/23/2009 Ví d Khai báo bi n s nguyên, “a” “b” #include #include int int main(void) main(void) {{ int int a, a, b; b; Nh p s nguyên vào a b printf(“Nhap printf(“Nhap 22 so so ngguyen: ngguyen: "); "); scanf("%i %i", &a, &b); scanf("%i %i", &a, &b); printf("%i printf("%i %i %i == %i\n", %i\n", a, a, b, b, aa b); b); Vi t bi u th c “a”, “b” “a-b” theo nh }} ng %i NH P MƠN L P TRÌNH return return 0; 0; Nhap Nhap 22 so so nguyen: nguyen: 21 21 17 17 21 21 17 17 == 44 12/23/2009 Bi n – Variable int a, b; Ch a d li u có th thay i c ch ng trình Mu n s d ng ph i khai báo Tên: g m ch cái, ký s , d u n i (_), không u b ng ký s cb t Bi n khai báo kh i c g i bi n c c b , không thu c kh i c g i bi n tồn c c Có tác d ng tồn kh i k t lúc NH P MƠN L P TRÌNH c khai báo 12/23/2009 L nh xu t - printf Xu t d li u hình: printf("%i - %i = %i\n", a, b, a - b); Các ký t h ng c in nguyên v n Các ký t nh d ng th c t ng ng: %i: ký t c thay b ng giá tr c a bi u nh d ng s nguyên ki u int Các ký t i u n: \n – xu ng dòng; \t – d u tab; \\ – d u \; \“– d u “ … Th vi n: stdio.h NH P MÔN L P TRÌNH 12/23/2009 10 L nh nh p - scanf Nh p d li u t bàn phím scanf("%i %i", &a, &b); Trong chu i nh d ng ch có ký t kho ng tr ng D li u ph i nh d ng c nh p vào bi n Tr c tên bi n ph i ghi d u & - toán t a ch N u khơng có tốn t a ch , giá tr c a bi n s không c c p nh t Th vi n: stdio.h NH P MƠN L P TRÌNH 12/23/2009 Ki u d li u c s C 11 Các ki u s nguyên c a C C h tr nhi u ki u s nguyên Các giá tr l n nh t nh nh t vi n “limits.h” c nh ngh a th Ki u nh d ng kích th c nh nh t l n nh t char %c CHAR_MIN CHAR_MAX unsigned char %c UCHAR_MAX short [int] %hi SHRT_MIN SHRT_MAX unsigned short%hu USHRT_MAX int %i or INT_MIN INT_MAX unsigned int %u or UINT_MAX long [int] %li LONG_MIN LONG_MAX unsigned long %lu ULONG_MAX NH P MƠN L P TRÌNH 12/23/2009 13 Ví d v s nguyên #include #include #include #include int int main() main() {{ unsigned unsigned long long big big == ULONG_MAX; ULONG_MAX; printf("minimum printf("minimum int int == %i, %i, ", ", INT_MIN); INT_MIN); printf("maximum int = %i\n", INT_MAX); printf("maximum int = %i\n", INT_MAX); printf("maximum printf("maximum unsigned unsigned == %u\n", %u\n", UINT_MAX); UINT_MAX); printf("maximum long int = %li\n", printf("maximum long int = %li\n", LONG_MAX); LONG_MAX); printf("maximum printf("maximum unsigned unsigned long long == %lu\n", %lu\n", big); big); return return 0; 0; }} NH P MÔN L P TRÌNH minimum minimum int int == -32768, -32768, maximum maximum int int == 32767 32767 maximum unsigned = 65535 maximum unsigned = 65535 maximum maximum long long int int == 2147483647 2147483647 maximum maximum unsigned unsigned long long == 4294967295 4294967295 12/23/2009 14 Ví d ki u ký t In mã ASCII c a ký t #include #include #include #include int int main() main() {{ char char lower_a lower_a == 'a'; 'a'; char lower_m = 'm'; char lower_m = 'm'; Trong NNLT C, ký t s nguyên printf("minimum printf("minimum char char == %i, %i, ", ", CHAR_MIN); CHAR_MIN); printf("maximum char = %i\n", CHAR_MAX); printf("maximum char = %i\n", CHAR_MAX); printf(“Sau printf(“Sau '%c' '%c' la la '%c'\n", '%c'\n", lower_a, lower_a, lower_a lower_a ++ 1); 1); printf(“Ky tu in hoa '%c'\n", lower_m 'a' + 'A'); printf(“Ky tu in hoa '%c'\n", lower_m - 'a' + 'A'); return return 0; 0; }} minimum minimum char char == -128, -128, maximum maximum char char == 127 127 Sau 'a' la 'b' Sau 'a' la 'b' Ky Ky tu tu in in hoa hoa 'M' 'M' NH P MÔN L P TRÌNH 15 12/23/2009 S nguyên c s khác Các h s có th th c hi n c: 10 (decimal), s 16 (hexadecimal) s (octal), 0: s octal s 0x: s hexadecimal #include #include int int main(void) main(void) {{ int int dec dec == 20, 20, oct oct == 020, 020, hex hex == 0x20; 0x20; printf("dec=%d, printf("dec=%d, oct=%d, oct=%d, printf("dec=%d, oct=%o, printf("dec=%d, oct=%o, return return 0; 0; }} NH P MÔN L P TRÌNH hex=%d\n", hex=%d\n", dec, dec, oct, oct, hex=%x\n", dec, oct, hex=%x\n", dec, oct, dec=20, dec=20, oct=16, oct=16, dec=20, oct=20, dec=20, oct=20, 12/23/2009 hex); hex); hex); hex); hex=32 hex=32 hex=20 hex=20 16 S th c C h tr nhi u ki u s th c l u tr d u ch m ng Các giá tr l n nh t nh nh t c nh ngh a th vi n “float.h” Ki u nh d ng kích th float %f %e %g double %lf %le %lg long double %Lf %Le %Lg 10 NH P MÔN L P TRÌNH c nh nh t n nh t FLT_MIN FLT_MAX DBL_MIN DBL_MAX LDBL_MIN LDBL_MAX 17 12/23/2009 Ví d s th c: #include #include #include #include int int main(void) main(void) {{ double double ff == 3.1416, 3.1416, gg == 1.2e-5, 1.2e-5, hh == 5000000000.0; 5000000000.0; printf("f=%lf\tg=%lf\th=%lf\n", printf("f=%lf\tg=%lf\th=%lf\n", f, f, g, g, h); h); printf("f=%le\tg=%le\th=%le\n", f, g, h); printf("f=%le\tg=%le\th=%le\n", f, g, h); printf("f=%lg\tg=%lg\th=%lg\n", printf("f=%lg\tg=%lg\th=%lg\n", f, f, g, g, h); h); printf("f=%7.2lf\tg=%.2le\th=%.4lg\n", printf("f=%7.2lf\tg=%.2le\th=%.4lg\n", f, f, g, g, h); h); return return 0; 0; }} f=3.141600 f=3.141600 f=3.141600e+00 f=3.141600e+00 f=3.1416 f=3.1416 f= 3.14 f= 3.14 NH P MÔN L P TRÌNH g=0.000012 g=0.000012 g=1.200000e-05 g=1.200000e-05 g=1.2e-05 g=1.2e-05 g=1.20e-05 g=1.20e-05 12/23/2009 h=5000000000.000000 h=5000000000.000000 h=5.000000e+09 h=5.000000e+09 h=5e+09 h=5e+09 h=5e+09 h=5e+09 18 H ng – Constant const int days_in_week = 7; Ch a d li u không th thay i c ch ng trình Mu n s d ng ph i khai bá báo Ph i có ki u ( ng t nh bi n) H ng s có ch a “.” ho c “e” có ki u double (3.5, 1e1e-7, -1.29e15) H ng s ki u float k t thú thúc b i “F” (3.5F, 1e1e-7F) H ng s ki u long double double k t thú thúc b i “L” (-1.29e15L, 1e1e-7L) H ng s khơng có có “.”, “e” ho c “F” có ki u int Ví d : 10000, -35 (M t ng chuy n vài trì trình biên d ch t thành long int n u giá giá tr h ng tràn ki u int) Khai bá báo h ng long int ph i thêm vào cu i “L” (9000000L) NH P MÔN L P TRÌNH 12/23/2009 19 Ví d v h ng Các h ng pi, days_in_week, sunday c t o v i t khóa const #include #include L i int intmain(void) main(void) {{ const const long long double double pi pi == 3.141592653590L; 3.141592653590L; const const int int days_in_week days_in_week == 7; 7; const const sunday sunday == 0; 0; days_in_week days_in_week == 5; 5; return return 0; 0; }} NH P MƠN L P TRÌNH 12/23/2009 20 H ng x lý tr c biên d ch Các h ng có th c xác l p tr c biên d ch B n ch t tìm ki m thay th Th ng c t tên v i ch in hoa Tìm t “PI”, thay b ng 3.1415 #include #include #define #definePI PI #define DAYS_IN_WEEK #define DAYS_IN_WEEK #define #defineSUNDAY SUNDAY 3.141592653590L 3.141592653590L 77 00 u ý: khơng có “=” “;” int int day day == SUNDAY; SUNDAY; long long flag flag == USE_API; USE_API; Khơng thay th “PI” NH P MƠN L P TRÌNH 12/23/2009 Tốn t C 21 Tốn t C Phé Phép toá toán s h c Ép ki u Các toán t bit Các toán t so sánh Phép gán Toá Toán t sizeof Bi u th c i u ki n NH P MÔN L P TRÌNH 12/23/2009 23 Tốn t s h c NNLT C h tr phép toán s h c: + c ng tr * nhân / chia % chia l y d u ý: ý: “/” cho k t qu ph thu c vào ki u c a toán h ng “%” không th c hi n c v i s th c NH P MÔN L P TRÌNH 12/23/2009 24 Ví d v tốn t chia “/” Trình biên d ch d a vào ki u c a toán h ng nh phép chia t ng ng “i”, “j” ki u int, “/” phép chia l y nguyên k nh n giá tr int int main(void) main(void) {{ int ii == 5, int 5, double f = 5.0, double f = 5.0, “f”, “g” ki u double, “/” phép chia s th c h nh n giá tr 1.25 Phép chia nguyên, b t “h” có ki u double t qu 1.00000 kk hh hh == == == ii ff ii // // // jj gg == == quy t 4, 4, 4.0, 4.0, k; k; h; h; j; j; g; g; j; j; return return 0; 0; }} NH P MÔN L P TRÌNH 12/23/2009 25 Ép ki u Ép ki u làm thay bi u th c i t m th i ki u c a m t bi n m t int int main(void) main(void) {{ int int ii == 5, 5, jj == 4; 4; double f; double f; ff ff ff ff Phép chia s nguyên c th c hi n, k t qu , 1, c i sang ki u double, 1.00000 == == == == (double)i (double)i // j; j; ii // (double)j; (double)j; (double)i (double)i // (double)j; (double)j; (double)(i (double)(i // j); j); return return 0; 0; }} NH P MÔN L P TRÌNH 12/23/2009 26 Phép t ng (gi m) NNLT C có c bi t h tr vi c t ng (gi m) giá có tố tốn t giá tr c a m t bi n thay i n v ++ ng gi m Các tốn t có th “i” “j” t tr “i” NH P MƠN L P TRÌNH Tr c ho c sau bi n int int ii == 5, 5, jj == 4; 4; ii ++; ++; - j; j; ++ ++ i; i; 27 12/23/2009 c hay sau ? Th t th c hi n toán t ++ ph thu c vào v trí c a chúng (t c hay sau) so v i bi n: #include #include int intmain(void) main(void) {{ int i, int i, jj == 5; 5; ii == ++j; ++j; printf("i=%d, printf("i=%d, j=%d\n", j=%d\n", jj == 5; 5; ii == j++; j++; printf("i=%d, printf("i=%d, j=%d\n", j=%d\n", return return 0; 0; }} NH P MÔN L P TRÌNH ng j++; i = j; i, i, j); j); ng i = j; j++; ng: ng: i, i, j); j); i=6, i=6, i=5, i=5, 12/23/2009 j=6 j=6 j=6 j=6 28 Ki u lu n lý C Trong C khơng có ki u d li u lu n lý (th hi n giá tr ÚNG – SAI), thay vào ó bi u th c so sánh s cho k t qu S Giá tr (0.0) ng v i k t qu SAI (FALSE) Các giá giá tr khác nh 1, -3.5, -7, 10.4, … (khá (khác không) u c xem ÚNG (TRUE) NH P MƠN L P TRÌNH 12/23/2009 29 Các toán t so sánh NNLT C h tr phé phép so sá sánh: < >= == != bé n bé n hay b ng l nh n l n h n hay b ng b ng không b ng T t c u cho k t qu so sánh úng tr ng h p ng c l i NH P MƠN L P TRÌNH 12/23/2009 30 Tốn t lu n lý NNLT C h tr toá toán t lu n lý: && || ! (and) ho c (or) ph nh (not) T tc u cho k t qu ho c ÚNG ho c SAI ng ng tr ng h p int int i, i, jj == 10, 10, kk == 28; 28; ii == ((j ((j >> 5) 5) && && (k (k > 24); 24); NH P MƠN L P TRÌNH 31 12/23/2009 Tốn t lu n lý u ý s d ng cá tố tốn t lu n lý: N u khơng có có d u (), cá phé phép tố toán trái sang ph i c th c hi n t if((i if(i 10) && a[i] (a[i] >> 0) >> 0)) if((iy) ? x : y) NH P MƠN L P TRÌNH 39 12/23/2009 u tiên c a toán t Th t th c hi n toán t m t bi u th c ph thu c vào u tiên c a chúng Có 15 m c u tiên Thơng th ng, tốn t m t ngơi có u tiên cao h n tốn t hai ngơi Các c p d u ngo c n () t ng c dùng ch rõ th t toán t #include #include int int main(void) main(void) {{ int int jj == 33 ** 44 ++ 48 48 // 7; 7; printf("j printf("j == %i\n", %i\n", j); j); return return 0; 0; NH P MƠN L P TRÌNH }} 12/23/2009 jj == 18 18 40 B ng th t th c hi n toán t Toán t Th () [] -> ! ++ - + (cast) * & sizeof * / % + > < = > == != & | ^ && || ?: = += -= *= /= %= … NH P MÔN L P TRÌNH (n u T) 41 12/23/2009 Luy n t p #include #include int int main(void) main(void) {{ int int ii == 0, 0, j, j, kk == jj == mm += += 2; 2; printf("j printf("j == %d\n", %d\n", jj == k++ > 7; k++ > 7; printf("j printf("j == %d\n", %d\n", jj == ii == & == & k; k; printf("j = %d\n", printf("j = %d\n", nn == !i !i >> kk >> >> 2; 2; printf("n = %d\n", printf("n = %d\n", return return 0; 0; }} NH P MƠN L P TRÌNH 12/23/2009 7, 7, mm == 5, 5, n; n; j); j); j); j); j); j); n); n); 42 Tóm l c M t s thành ph n c a ch ng trình C Hàm main L nh xu t / nh p – printf / scanf Bi n Các ki u s nguyên s th c H ng – cách khai báo S d ng toá toán t C NH P MƠN L P TRÌNH 12/23/2009 43 ... f= 3.14 f= 3.14 NH P MƠN L P TRÌNH g=0.000012 g=0.000012 g=1.200000e-05 g=1.200000e-05 g=1.2e-05 g=1.2e-05 g=1.20e-05 g=1.20e-05 12/23/2009 h=5000000000.000000 h=5000000000.000000 h=5.000000e+09... “e” có ki u double (3.5, 1e1e-7, -1 .29e15) H ng s ki u float k t thú thúc b i “F” (3.5F, 1e1e-7F) H ng s ki u long double double k t thú thúc b i “L” (-1 .29e15L, 1e1e-7L) H ng s khơng có có “.”,... ÚNG), tr ng h p khác nh n giá tr BT2 int int i, i, jj == 100, 100, kk == -1 ; -1 ; int int i, i, jj == 100, 100, kk == -1 ; -1 ; ii == (j (j >> k) k) ?? jj :: k; k; ii == (j (j

Ngày đăng: 08/05/2021, 14:12