Kĩ thuật lập trình - Chương 1: Kiến thức cơ bản về ngôn ngữ lập trình C/C++

Viết các chương trình sau bằng phương pháp sử dụng hàm con. 1. Viết chương trình nhập vào 1 số nguyên dương n. Tìm và in ra các số nguyên tố nho hơn n. 2. Viết chương trình nhập 2 số nguyên dương a, b. Tìm USCLN và BSCNN của hai số nguyên đó 3. Viết chương trình nhập số nguyên dương n, tính tổng các ước số dương của n. Ví dụ: Nhâp n=6 Tổng các ước sô từ 1 đến n: 1+2+3+6=12.

pdf52 trang | Chia sẻ: nguyenlam99 | Lượt xem: 1094 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Kĩ thuật lập trình - Chương 1: Kiến thức cơ bản về ngôn ngữ lập trình C/C++, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
KIẾN THỨC CƠ BẢN VỀ NGÔN NGỮ LẬP TRÌNH C/C++ KỸ THUẬT LẬP TRÌNH NÂNG CAO TRƢỜNG CAO ĐẲNG CNTT TP.HCM KHOA CÔNG NGHỆ THÔNG TIN Chƣơng 1: Giảng Viên: ThS. Dƣơng Thành Phết Email: phetcm@gmail.com Website: Tel: 0918158670 – facebook.com/DuongThanhPhet 1. TẠO PROJECT VỚI VS 2010  Bước 1: Khởi động Visual Studio 2010  Bước 2: Chọn menu File / New / Project Chọn ngôn ngữ C++ , Chọn kiểu project là Win32 Console Application; Đặt tên cho ứng dụng ở mục Name; Click Browse để chọn vị trí lưu Project và OK 1. TẠO PROJECT VỚI VS 2010  Bƣớc 3: Chọn kiểu ứng dụng Console và chọn Empty Project. Nhấn Finish để hoàn tất. 1. TẠO PROJECT VỚI VS 2010  Giao diện sau khi tạo Project Cửa số Explorer để quản lý các file trong Project Chọn Solution Explorer 1. TẠO PROJECT VỚI VS 2010 Cửa sổ gồm 2 giao diện chính :  Vùng trống bên trái để viết Code  Phía bên phải quản lý các file trong Project Có 3 thƣ mục chính ở cửa số Explorer:  Source Files (*.cpp): Chứa các file cài đặt các hàm  Header Files (*.h): Chứa các file khai báo  Resource Files: Chứa các tài nguyên (icon, bitmap,. . .) 1. TẠO PROJECT VỚI VS 2010 Qui ƣớc: Để dễ dàng viết và quản lý code theo phương pháp lập trình thủ tục, mỗi Project mới, ta qui ước như sau: Trong Header File:  Khaibao.H: Chứa các khai báo hàm, hằng số, Trong Source File:  Main.cpp: Cài đặt hàm main()  Caidat.cpp: Cài đặt các hàm con đã khai báo 1. TẠO PROJECT VỚI VS 2010 Tạo file khai báo (khaibao.h)  Click phải thư mục Header Files  Chọn Add  Chọn New Item 1. TẠO PROJECT VỚI VS 2010  Chọn Code, Header File (.h)  Nhập khaibao.h vào ô Name  Chọn OK, sau đó chọn Yes 1. TẠO PROJECT VỚI VS 2010 Tạo file cài đặt (Main.cpp, Caidat.cpp)  Click phải thư mục Source File -> chọn Add  chọn New Item  Chọn Code, CPP File (.cpp)  Nhập Main.Cpp vào ô Name, chọn OK, chọn Yes  Tương tự, tiếp tục tạo file caidat.cpp 1. TẠO PROJECT VỚI VS 2010 Khaibao.h #include using namespace std; void Nhap(int &a, int &b); long Tong(int a, int b); 1. TẠO PROJECT VỚI VS 2010 Ví dụ: Viết chương trình nhập vào 2 số nguyên a, b. Tính tổng và xuất ra màn hình. Main.Cpp #include "khaibao.h" void main() { int a, b; long s; Nhap(a, b); s = Tong(a, b); cout<<"Tong a va b: "<<s; } 1. TẠO PROJECT VỚI VS 2010 Caidat.Cpp #include "khaibao.h" void Nhap(int &a, int &b) { cout<<"Nhap so nguyen thu nhat: "; cin>>a; cout<<"Nhap so nguyen thu hai: "; cin>>b; } long Tong(int a, int b) { return a + b; } 1. TẠO PROJECT VỚI VS 2010 Dịch, sửa lỗi và chƣơng trình  Biên dịch và kiểm tra lỗi: Nhấn Ctrl + Shift + B  Nếu có thông báo lỗi (error) thì quan sát và sửa lỗi (cửa sổ lỗi xuất hiện bên dưới màn hình soạn thảo code)  Chạy chương trình: Ctrl + F5 (hoặc F5) 1. TẠO PROJECT VỚI VS 2010 Kết quả chạy chương trình (Ctrl + F5) 1. TẠO PROJECT VỚI VS 2010 Cách 1:  Khởi động VS  Vào menu File/ Open / Project or Solution  Chọn thư mục chứa Project  Chọn tên Project  Open 2. MỞ PROJECT Cách 2:  Mở thư mục chứa Project  Double click vào file *.sln 2. MỞ PROJECT 18 3.1. Lệnh Lệnh là một biểu thức, thực hiện một chức năng: khai báo, gán, xuất, nhập, tính toán được kết thúc là ; Không nên đặt nhiều lệnh trên cùng một dòng 3.2. Khối lệnh Khối lệnh gồm nhiều lệnh được đặt trong cặp dấu ngoặc { . . . } 18 3. CÁC KIẾN THỨC CƠ BẢN TRONG C++ 3.3. Lời chú thích (comment): 1 dòng: // . . . . . Nhiều dòng: /* . . . . . . . . */ 19 19 3.4. Kiểu dữ liệu Kiểu dữ liệu tập các giá trị thuộc một kiểu nào đó. Gồm 2 loại:  Kiểu cơ sở: Số nguyên; Số thực; Luận lý ; Mảng; Chuỗi  Kiểu tự định nghĩa: Dùng những kiểu cơ sở để xây dựng thành những kiểu dữ liệu mới cho phù hợp với bài toán (Kiểu cấu trúc - struct). 3. CÁC KIẾN THỨC CƠ BẢN TRONG C++ 20 STT KIỂU GHI CHÚ KÍCH THƢỚC KIỂU LIÊN TỤC (SỐ THỰC) 1 float 4 bytes 2 double 8 bytes 3 long double 8 bytes KIỂU RỜI RẠC (SỐ NGUYÊN) 1 char Ký tự hoặc Số nguyên 1 byte 2 unsigned char Số nguyên dương 1 byte 3 short Số nguyên 2 bytes 4 unsigned short Số nguyên dương 2 bytes 5 int Số nguyên 4 bytes 6 unsigned int Số nguyên dương 4 bytes 7 long Số nguyên 4 bytes 8 unsigned long Số nguyên dương 4 bytes KIỂU LUẬN LÝ 1 bool Gồm 2 giá trị: true hoặc false 20 3. CÁC KIẾN THỨC CƠ BẢN TRONG C++ 21 3.5. Biến  Một biến đại diện cho một vùng nhớ của máy tính.  Tên biến được dùng để tham khảo đến những vùng nhớ này.  Biến để lưu trữ các giá trị do người dùng nhập vào hoặc các giá trị tạm thời trong quá trình tính toán.  Mỗi biến sẽ có tên và kiểu dữ liệu tương ứng.  Phải khai báo Biến trước khi sử dụng 21 3. CÁC KIẾN THỨC CƠ BẢN TRONG C++ 22 Khai báo biến Cú pháp tênbiến; 22 Ví dụ: int a; //Khai báo biến để lưu số nguyên tên a float c; //Khai báo biến để lưu số thực tên c Khai báo nhiều biến cùng kiểu tênbiến1, tênbiến2, tênbiến3; Ví dụ: int a, x, y; 3. CÁC KIẾN THỨC CƠ BẢN TRONG C++ 23  Bắt đầu bằng một ký tự.  Bao gồm: các ký tự chữ, số hoặc dấu gạch dưới (_)  Không có khoảng trắng trong tên biến.  Không dài quá 256 ký tự.  Không được trùng với các từ khoá của C struct, long, int, while, for, if, else, continue, typedef, do, goto, case, define,  Không được trùng với phạm vi khai báo.  Tên gợi nhớ. Phân biệt chữ hoa và thường 23 Qui tắc đặt tên biến 3. CÁC KIẾN THỨC CƠ BẢN TRONG C++ 24 3.6. Hằng 24 Hằng là các đại lượng mà giá trị của nó không thay đổi trong suốt chương trình . Khai báo hằng: #define tênhằng giátrị; Ví dụ : #define MAX 1000; #define pi 3.141593; 3. CÁC KIẾN THỨC CƠ BẢN TRONG C++ 25 25 STT PHÉP TOÁN Ý NGHĨA PHÉP TOÁN SỐ HỌC 1 + Cộng 2 - Trừ 3 * Nhân 4 / Chia lấy phần nguyên 5 % Chia lấy phần dư PHÉP TOÁN QUAN HỆ 1 > Lớn hơn 2 < Nhỏ hơn 3 >= Lớn hơn hoặc bằng 4 <= Nhỏ hơn hoặc bằng 5 == Bằng nhau 6 != Khác nhau 3.7. Các phép toán 3. CÁC KIẾN THỨC CƠ BẢN TRONG C++ 26 26 PHÉP TOÁN LOGIC 1 ! NOT Không 2 && AND Và 3 || OR Hoặc TOÁN TỬ TĂNG GIẢM 1 ++ Tăng 1 2 -- Giảm 1 PHÉP TOÁN THAO TÁC TRÊN BIT 1 & AND 2 | OR 3 ^ XOR 4 << Dịch trái 5 >> Dịch phải 6 ~ Lấy phần bù theo bit 3. CÁC KIẾN THỨC CƠ BẢN TRONG C++ 27 Cú pháp: (BT Đ.kiện)?: Ví dụ: int n; (n%2==0)? n ++ : n --;  nếu n = 10 thì giá trị n = 11  nếu n = 21 thì giá trị n = 20 27 3.8. Toán tử điều kiện 3. CÁC KIẾN THỨC CƠ BẢN TRONG C++ 28 28 Thứ tự ưu tiên của các phép toán thường dùng theo trật tự từ trái sang phải từ trên xuống dưới như sau: () [ ] -- ++ & ! * / % + - >= == != && || Thứ tự ƣu tiên các phép toán 3. CÁC KIẾN THỨC CƠ BẢN TRONG C++ 29 3.9. Hàm nhập xuất Thƣ viện hàm: iostream.h Hàm nhập giá trị từ bàn phím: cin>>tênbiến; Ví dụ: int a; cin>>a; //Nhập giá trị từ phím sẽ lưu vào biến a Hàm xuất giá trị ra màn hình: cout<<tênbiến hoặc chuỗi ký tự; Ví dụ: int a = 5, b-7; cout<<“Gia tri cua a = “<<a<<“b=“<<b; Ví dụ: int b = 7, c = 9; cout<< “Gia tri của b =“ << b << “ gia tri cua c = “ << c; 29 3. CÁC KIẾN THỨC CƠ BẢN TRONG C++ 30 Xuất có định dạng Thƣ viện iomanip.h cout<<setw(n)<<tênbiến;  Chừa 1 khoảng n ký tự để xuất giá trị 30 Ví dụ: int a=7, b=9; cout<<a<<setw(5)<<b;//Chừa 5 vị trí để xuất giá trị b Kết quả: 7 9 3. CÁC KIẾN THỨC CƠ BẢN TRONG C++ 31 cout<<setprecision(n) <<tênbiến; ;  Xuất số thập phân gồm n-1 chữ số lẻ(phần thập phân) 31 Ví dụ: float a=7.56745F, b=5.339F; cout<<a<<endl; cout<<setprecision(3)<<a<<endl; cout<<setprecision(2)<<b<<endl; Kết quả: 7.56745 7.57 5.3 5.339 3. CÁC KIẾN THỨC CƠ BẢN TRONG C++ 32 Xuất ký tự đặc biệt Ký tự Ý nghĩa Ví dụ \‟ Xuất dấu nháy đơn cout<<“ \‟ ”; Kết quả: „ \” Xuất dấu nháy đôi cout<<“ \” ”; Kết quả: “ \\ Xuất dấu chéo ngược \” cout<<“ \\ ”; Kết quả: \ \0 Ký tự Null Gán ký tự kết thúc của chuỗi \a Alert : Tiếng bip \t Tab vào một đoạn cout<<"xyz\tzyx”; Kết quả: xyz zyx \b Xuất lùi về sau cout<<"xyz\t\bzyx”; Kết quả: xyzzyx \n hoặc endl Xuống dòng cout<<"xyz\nzyx”; Kết quả: xyz zyx \r Về đầu dòng cout<<"xyz\rzyx”; Kết quả: zyx 32 3. CÁC KIẾN THỨC CƠ BẢN TRONG C++ 4. CẤU TRÚC ĐIỀU KHIỂN if ( Biểu thức ĐK) khối lệnh 1; . . . . . . . if ( Biểu thức ĐK ) khối lệnh 1; else khối lệnh 2 ; . . . . . . . - Nếu biểu thức đúng thì sẽ thực hiện khối lệnh 1 - Sau đó sẽ thực hiện các lệnh tiếp sau khối lệnh 1.. - Nếu biểu thức đúng thì sẽ thực hiện khối lệnh 1 - Nếu biểu thức sai thì bỏ qua khối lệnh 1 mà thực hiện khối lệnh 2 . - Sau đó thực hiện tiếp các lệnh tiếp sau. 4.1 Cấu rẽ nhánh (if . . . .else . . . ) 34 Ví dụ: Giải và biện luận phương trình: ax+b=0 34 4. CẤU TRÚC ĐIỀU KHIỂN 35 void main() { float a, b; cout<<"Nhap vao a: "; cin>>a; cout<<"Nhap vao b: "; cin>>b; if (a == 0) if (b == 0) cout<<"Phuong trinh vo so nghiem"<<endl; else cout<<"Phuong trinh vo nghiem"<<endl; else cout<<"Phuong trinh co nghiem x = "<< -b / a<<endl; } 35 4. CẤU TRÚC ĐIỀU KHIỂN Ví dụ: Giải và biện luận phương trình: ax+b=0 36 switch (biểu thức)  case n1: các câu lệnh ; break ; case n2: các câu lệnh ; break ; case nk: ; break ; [default: các câu lệnh]  36 4.2 Cấu trúc lựa chọn ni là các hằng số nguyên hoặc ký tự 4. CẤU TRÚC ĐIỀU KHIỂN 37 void main() { int n; cout<<"Nhap vao n (1<=n<=5): "; cin>>n; switch (n) { case 1: cout<<"So mot";break; case 2: cout<<"So hai";break; case 3: cout<<"So ba"; break; case 4: cout<<"So bon"; break; case 5: cout<<"So nam"; break; default : cout<<"Khong doc duoc"; } } 37 4. CẤU TRÚC ĐIỀU KHIỂN 38 38 4.3. Cấu trúc lặp - for for ( ; ; ) { ; } Bất kỳ biểu thức nào trong 3 biểu thức nói trên đều có thể vắng nhưng phải giữ dấu chấm phẩy (;) 4. CẤU TRÚC ĐIỀU KHIỂN Thöïc hieän caùc leänh trong voøng laëp Khôûi gaùn Ñuùng (Bieåu thöùc ñieàu kieän khaùc 0)Kieåm tra bieåu thöùc ñieàu kieän Taêng/ giaûm chæ soá laëp Sai (Biểu thức ñiều kiện = 0) 39 while ( )  khối lệnh;  39 4.4. Cấu trúc lặp - while Kiểm tra điều kiện của biểu thức điều kiện. Nếu biểu thức điều kiện bằng true thì thực hiện các lệnh trong vòng lặp, Quay lặp lại. Ngược lại thoát khỏi lặp. 4. CẤU TRÚC ĐIỀU KHIỂN 40 do { ; } while (biểu thức điều kiện); 40 4.5. Cấu trúc lặp – do . . .While  Thực hiện khối lệnh cho đến khi biểu thứcn điều kiện có giá trị bằng false.  Cấu trúc lặp dowhile ít nhất thực hiện khối lệnh được 1 lần 4. CẤU TRÚC ĐIỀU KHIỂN 41 4.6. Lệnh break: Thoát khỏi các cấu trúc switch, while, for, dowhile chứa nó gần nhất. 41 4. CẤU TRÚC ĐIỀU KHIỂN 4.7. Lệnh continue:  Được sử dụng trong các vòng lặp như while, for, dowhile.  Khi lệnh continue được gọi thì chương trình sẽ quay trở về đầu vòng lặp để bắt đầu lần lặp mới  Nếu có các lệnh còn lại (cùng trong vòng lặp) đặt sau continue sẽ không được thực hiện. 42 5.1. Khái niệm  Hàm-Function  Là một đoạn chương trình độc lập thực hiện trọn vẹn một công việc nhất định sau đó trả về gia ́ trị cho chương trình gọi nó  Là sự chia nhỏ của chương trình.  Mục đích sử dụng hàm: - Khi có một công việc giống nhau cần thực hiện ở nhiều vị trí. - Khi cần chia một chương trình lớn phức tạp thành các đơn thể để chương trình được trong sáng, dễ hiểu trong việc xử lý. 42 5. XÂY DỰNG HÀM CON 43 43 5.2. Khai báo và sử dụng hàm Type tênhàm(Các tham số){ Khai báo các biến cục bộ; Các câu lệnh; [return [biểu thức];] } Type: Kiểu dữ liệu giá trị trả về của hàm Kiểu dữ liệu trả về của hàm gồm 2 loại  void: Không trả về giá trị  float / int / long / char */ kiểu cấu trúc / : Trả về giá trị kết quả có kiểu dữ liệu tương ứng Thân hàm 5. XÂY DỰNG HÀM CON 44 int Tong(int a, int b) { int s=a+b; return s; } void main() { int kq = Tong (12, 3); cout<<“Tong cua 12 va 3: “<<kq; } 44 Truyền đối số Tham số Gọi hàm 5. XÂY DỰNG HÀM CON 45 Ví dụ: Viết chương trình nhập số nguyên dương n va ̀ in ra màn hình các ước số của n Phân tích bài toán:  Input: n (tham số) Kiểu dữ liệu: số nguyên dương (int).  Output: In ra các ước số của n (dữ liệu trả về của hàm) Xuất ra màn hình Không trả về giá trị (Kiểu void)  Xác định tên hàm: Hàm này dùng in ra các ước số của n nên có thể đặt là LietKeUocS void LietKeUocSo(int n); 45 5. XÂY DỰNG HÀM CON 46 File khaibao.h #include “iostream” using namespace std; void LietKeUocSo(int n); 46 File caidat.cpp #include “khaibao.h” void LietKeUocSo(int n){ for (int i = 1; i <= n; i++) if (n % i == 0) cout<<i<<“\t”; } File main.cpp #include “khaibao.h” void main(){ int n; cout<<"Nhap so nguyen duong n: "; cin>>n; cout<<"Cac uoc so cua “<<n<<“: “; LietKeUocSo(n); } Ví dụ: Viết chương trình in ra các ước số của n 5. XÂY DỰNG HÀM CON 47 Ví dụ 2: Viết chương trình nhập số nguyên dương n và tính tổng: Sn=1+2+3+ . . .+n ; với n>0 Phân tích bài toán:  Input: n (tham số) Kiểu dữ liệu: số nguyên dương (int).  Output: Trả về giá trị của S. S là tổng các số nguyên dương nên S cũng là số nguyên dương  Kiểu trả về của hàm là int (hoặc long).  Xác định TênHàm: Dùng tính tổng S nên có thể đặt là TongS int TongS(int n); 47 5. XÂY DỰNG HÀM CON 48 File khaibao.h #pragma once #include int TongS(int n); 48 File caidat.cpp #include “khaibao.h” int TongS(int n){ int kq = 0; for (int i = 1; i <= n; i++) kq + = i; return kq; } File main.cpp #include “khaibao.h” void main(){ int n, S; cout<<"Nhap vao so nguyen n: "; cin>>n; S = TongS(n); cout<<"Tong tu 1 den n: " <<S; } Ví dụ 2: Viết chương trình nhập số nguyên dương n và tính tổng: Sn=1+2+3+ . . .+n ; với n>0 5. XÂY DỰNG HÀM CON 49 5.3. Tham số là tham chiếu  Tham số làm kết quả đầu ra  Tham số vừa làm đầu vào và đầu ra  Dùng dấu & phía trước tên tham số khi cài đặt hàm 49 5. XÂY DỰNG HÀM CON 50 Ví dụ: Chương trình hoán vị 2 số nguyên a, b cho trước 50 void HoanVi(int &a, int &b) { int tam = a; a = b; b = tam; cout<<"Trong HoanVi: a = “<<a<<“ ;b = “<<b; } void main(){ int a = 5, b = 21; cout<<"Truoc khi HoanVi: a = “<<a<<“ ; b = “<<b; HoanVi(a, b); cout<<"Sau khi goi HoanVi: a = “<<a<<“ ;b = “<<b; } 5. XÂY DỰNG HÀM CON 51 BÀI TẬP Viết các chương trình sau bằng phương pháp sử dụng hàm con. 1. Viết chương trình nhập vào 1 số nguyên dương n. Tìm và in ra các số nguyên tố nhỏ hơn n. 2. Viết chương trình nhập 2 số nguyên dương a, b. Tìm USCLN và BSCNN của hai số nguyên đó 3. Viết chương trình nhập số nguyên dương n, tính tổng các ước số dương của n. Ví dụ: Nhập n=6 Tổng các ước số từ 1 đến n: 1+2+3+6=12. 51 52 The End.

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

  • pdfchuong01_9062.pdf