Funclass Forum | 122's Mini Forum
Forum Funclass.coo.me Rất vui Vì các bạn đã ghé thăm
Funclass Forum | 122's Mini Forum
Forum Funclass.coo.me Rất vui Vì các bạn đã ghé thăm
Funclass Forum | 122's Mini Forum
Bạn có muốn phản ứng với tin nhắn này? Vui lòng đăng ký diễn đàn trong một vài cú nhấp chuột hoặc đăng nhập để tiếp tục.


Funclass.coo.me
 
Trang ChínhPortalGalleryTìm kiếmLatest imagesĐăng kýĐăng NhậpSite Kỷ Niệm

Share | 
 

 Một Số Giải Thuật Cơ Bản

Xem chủ đề cũ hơn Xem chủ đề mới hơn Go down 
Tác giảThông điệp
monkeydkzat
Chủ Tịch Quốc Hội
Chủ Tịch Quốc Hội
monkeydkzat

Cầm Tinh : Scorpio
Tổng số bài gửi : 132
Vàng : 623
Thanks: : 0
Birthday : 20/11/1993
Join date : 19/03/2010
Age : 30
Đến từ : Bến Tre

Một Số Giải Thuật Cơ Bản Empty
Bài gửiTiêu đề: Một Số Giải Thuật Cơ Bản   Một Số Giải Thuật Cơ Bản I_icon_minitimeFri Mar 19, 2010 2:04 pm

Một số giải thuật cơ bản

Ví dụ 1: Cần viết chương trình cho máy tính sao cho khi thực hiện chương trình đó, máy tính yêu cầu người sử dụng chương trình nhập vào các số hạng của tổng (n); nhập vào dãy các số hạng ai của tổng. Sau đó, máy tính sẽ thực hiện việc tính tổng các số ai này và in kết quả của tổng tính được.
Yêu cầu: Tính tổng n số S=a1+ a2+a3+......+an .
Để tính tổng trên, chúng ta sử dụng phương pháp “cộng tích lũy” nghĩa là khởi đầu cho S=0. Sau mỗi lần nhận được một số hạng ai từ bàn phím, ta cộng tích lũy ai vào S (lấy giá trị được lưu trữ trong S, cộng thêm ai và lưu trở lại vào S). Tiếp tục quá trình này đến khi ta tích lũy được an vào S thì ta có S là tổng các ai. Chi tiết giải thuật được mô tả bằng ngôn ngữ tự nhiên như sau:
- Bước 1: Nhập số các số hạng n.
- Bước 2: Cho S=0 (lưu trữ số 0 trong S)
- Bước 3: Cho i=1 (lưu trữ số 1 trong i)
- Bước 4: Kiểm tra nếu i<=n thì thực hiện bước 5, ngược lại thực hiện bước 8.
- Bước 5: Nhập ai
- Bước 6: Cho S=S+ai (lưu trữ giá trị S + ai trong S)
- Bước 7: Tăng i lên 1 đơn vị và quay lại bước 4.
- Bước 8: In S và kết thúc chương trình.
Chí tiết giải thuật bằng lưu đồ:

BeginS=0i=1EndS=S+aii=i+1Nhập số các số hạng ni<=n SaiĐúngNhập số ai In S
Ví dụ 2: Viết chương trình cho phép nhập vào 2 giá trị a, b mang ý nghĩa là các hệ số a, b của phương trình bậc nhất. Dựa vào các giá trị a, b đó cho biết nghiệm của phương trình bậc nhất ax + b = 0.
Mô tả giải thuật bằng ngôn ngữ tự nhiên:
- Bước 1: Nhập 2 số a và b
- Bước 2: Nếu a = 0 thì thực hiện bước 3, ngược lại thực hiện bước 4
- Bước 3: Nếu b=0 thì thông báo phương trình vô số nghiệm và kết thúc chương trình, ngược lại thông báo phương trình vô nghiệm và kết thúc chương trình.
- Bước 4: Thông báo nghiệm của phương trình là –b/a và kết thúc.
BeginEnd
Nhập hai số a,ba=0 Đúng b=0 ĐúngSai SaiNghiệm x=-b/a PT vô nghiệm PT vô định
Ví dụ 3: Viết chương trình cho phép nhập vào 1 số n, sau đó lần lượt nhập vào n giá trị a1, a2,…,an. Hãy tìm và in ra giá trị lớn nhất trong n số a1, a2, …, an.
Để giải quyết bài toán trên, chúng ta áp dụng phương pháp “thử và sửa”. Ban đầu giả sử a1 là số lớn nhất (được lưu trong giá trị max); sau đó lần lượt xét các ai còn lại, nếu ai nào lớn hơn giá trị max thi lúc đó max sẽ nhận giá trị là ai. Sau khi đã xét hết các ai thì max chính là giá trị lớn nhất cần tìm.
Mô tả giải thuật bằng ngôn ngữ tự nhiên:
- Bước 1: Nhập số n
- Bước 2: Nhập số thứ nhất a1
- Bước 3: Gán max=a1
- Bước 4: Gán i=2
- Bước 5: Nếu i<=n thì thực hiện bước 6, ngược lại thực hiện bước 9
- Bước 6: Nhập ai
- Bước 7: Nếu max < ai thì gán max=ai.
- Bước 8: Tăng i lên một đơn vị và quay lại bước 5
- Bước 9: In max - kết thúc
Phần mô tả giải thuật bằng lưu đồ, sinh viên tự làm xem như bài tập.
Ví dụ 4: Viết chương trình cho phép nhập vào 1 số n, sau đó lần lượt nhập vào n giá trị a1, a2,…,an. Sắp theo thứ tự tăng dần một dãy n số a1, a2,...an nói trên. Có rất nhiều giải thuật để giải quyết bài toán này. Phần trình bày dưới đây là một phương pháp.
Giả sử ta đã nhập vào máy dãy n số a1, a2,..., an. Việc sắp xếp dãy số này trải qua (n-1) lần:
- Lần 1: So sánh phần tử đầu tiên với tất cả các phần tử đứng sau phần tử đầu tiên. Nếu có phần tử nào nhỏ hơn phần tử đầu tiên thì đổi chỗ phần tử đầu tiên với phần tử nhỏ hơn đó. Sau lần 1, ta được phần tử đầu tiên là phần tử nhỏ nhất.
- Lần 2: So sánh phần tử thứ 2 với tất cả các phần tử đứng sau phần tử thứ 2. Nếu có phần tử nào nhỏ hơn phần tử thứ 2 thì đổi chỗ phần tử thứ 2 với phần tử nhỏ hơn đó. Sau lần 2, ta được phần tử đầu tiên và phần tử thứ 2 là đúng vị trí của nó khi sắp xếp.
- …
- Lần (n-1): So sánh phần tử thứ (n-1) với phần tử đứng sau phần tử (n-1) là phần tử thứ n. Nếu phần tử thứ n nhỏ hơn phần tử thứ (n-1) thì đổi chỗ 2 phần tử này. Sau lần thứ (n-1), ta được danh sách gồm n phần tử được sắp thứ tự.
Mô tả giải thuật bằng ngôn ngữ tự nhiên:
- Bước 1: Gán i=1
- Bước 2: Gán j=i+1
- Bước 3: Nếu i <=n-1 thì thực hiện bước 4, ngược lại thực hiện bước 8
- Bước 4: Nếu j <=n thì thực hiện bước 5, ngược lại thì thực hiện bước 7.
- Bước 5: Nếu ai > aj thì hoán đổi ai và aj cho nhau (nếu không thì thôi).
- Bước 6: Tăng j lên một đơn vị và quay lại bước 4
- Bước 7: Tăng i lên một đơn vị và quay lại bước 3
- Bước 6: In dãy số a1, a2,..., an - Kết thúc.
Mô tả giải thuật sắp xếp bằng lưu đồ
i=1j<=n-1j<=naj<aitam=aiai=ajaj=tamIn dãy số : a1, a2, …,anEndSaiĐúngĐúngĐúngj=i+1j=j+1Saii=i+1
Về Đầu Trang Go down
https://funclass.forum-viet.net
 

Một Số Giải Thuật Cơ Bản

Xem chủ đề cũ hơn Xem chủ đề mới hơn Về Đầu Trang 

 Similar topics

-
» Sơ Lược Về Giải Thuật
» Cấu Trúc Suy Luận Và Giải Thuật
» Ngôn Ngữ Biểu Diễn Giải Thuật
» Topic hỏi - đáp các vấn đề về thuật toán & lập trình!!!!!!!
Trang 1 trong tổng số 1 trang

Permissions in this forum:Bạn không có quyền trả lời bài viết
Funclass Forum | 122's Mini Forum :: Tin học :: Lập Trình Pascal-