Khoa Công Ngh Thông Tin
Môn: CTDL & GT

Bài thc hành s 1
Bài tp 1:
Viết chương trình minh ho các gii thut tìm kiếm và sp xếp trên mng có kích thước n phn
t nguyên. Chương trình được mô t vi các yêu cu như sau:
Cài đặt hàm tìm kiếm:
o Tìm kiếm tun t (tuyến tính) cho mng bt k
o Tìm kiếm nh phân cho mng d liu được sp tăng
Cài đặt các hàm sp xếp (tăng) theo phương pháp:
o Chn trc tiếp
o Chèn trc tiếp
o Ni bt
o Đổi ch trc tiếp
o Shell Sort
o Quick Sort
Các hàm sp xếp phi minh ho trc quan: ti mi bước hoán v a[i] và a[j]
Ví d: hoán v a[1] = 3 và a[6] = 2
Bước 1: di chuyn 3 xung dưới k dòng và 2 lên trên k dòng
Bước 2: di chuyn 3 qua v trí ct ca 2 và ngược li
Bước 3: di chuyn 2 xung và 3 lên đúng v trí cui cùng
Trường hp sp xếp theo kiu chèn hơi khác, sinh viên t tìm hiu và cài đặt minh ho cho thut
toán sp xếp chèn.
Lưu ý: mi hàm s có tham s vào là mng cn x lý và kích thước ca mng, không dùng biến toàn
cc.
Trong hàm main xây dng mt menu chn, cho phép nhp vào mt s ri thc hin chc năng
tương ng, menu có mô t như sau:
o Khi to mng d liu a, cho phép nhp vào n, sau đó chương trình phát sinh ngu nhiên
các phn t cho mng a
o Xem phn t ca mng
o Tìm kiếm tun t
o Tìm kiếm nh phân
o Sp xếp chn
o Sp xếp chèn
o . …
o 11. Sp xếp theo Radix Sort
o 12. Thoát
VD: khi user nhp 1 thì to mng, nhp 2 xem các phn t ca mng, còn 11 thc hin sp
xếp theo Radix Sort. Khi user nhp 12 thì kết thúc chương trình!
Lưu ý: khi chn chc năng tìm kiếm nh phân, thì phi kim tra xem mng đã được sp tăng
chưa, SV t cài đặt chc năng kim tra này.
Hướng dn
Phn định nghĩa các hng s dùng trong chương trình
Hàm xut mng
Hàm hoán v minh ha di chuyn tng bước
Hàm bubble sort s dng Swap trc quan trên
Minh ho 1 phn ca hàm main()
Gi ý chương trình:
//np thư vin
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
//định nghĩa hng
#define MAX 100
#define MAXV 100
//định nghĩa các hàm
//các hàm có protype như sau:
//ham nhap day so ngau nhien
void nhap(int a[], int &n);
//ham hien thi day so
void hienThi(int a[], int n);
//ham tim kiem su dung giai thuat tim kiem nhi phan
//tra lai ket qua -1 khong tim thay
//ngoai ra la vi tri tim duoc.
int timKiemTuyenTinh(int a[], int n, int x);
//ham tim kiem nhi phan
int timKiemNhiPhan(int a[], int n, int x);
//ham sap xep day so tang dung giai thuat sap xep noi bot
void sapXepNoiBot(int a[], int n);
//ham sap xep doi cho truc tiep
void sapXepDoiChoTrucTiep(int a[], int n);
//ham sap xep chen
void sapXepChen(int a[], int n);
//ham sap xep chon truc tiep
void sapXepChon(int a[], int n);
//ham sap xep shell sort
void shellSort(int a[], int n);
//ham sap xep nhanh
void quickSort(int a[], int n);
void main(){
//khai bao mang a luu day so ngau nhien
int a[MAX];
in n;
int chon;
//hien thi menu
do
{
//xoa man hinh
clrscr();
//hien thi menu
printf(”1: Tao day cac so ngau nhien”);
printf(”2: Tim kiem tuyen tinh ”);
printf(”3: Sap xep chon”);
printf(”4: Sap xep doi cho truc tiep”);
printf(”5: Sap xep noi bot”);
printf(“6: Sap xep chen”);
printf(”7: Shell Sort”);
printf(”8: Quick Sort”);
printf(”9: Tim kiem nhi phan”);
printf(”10: Hien thi day so”);
printf(”0 : Thoát”);
//doc chon lua cua nguoi dung
scanf(”%d”,&chon);
//xu ly lua chon tren menu
switch (chon){
case 1 :
//goi ham nhap day so ngau nhien
nhap(a,n);
break ;
case 2 :
//thong bao nhap vao so can tim
printf(“Cho biet so can tim:”);
int x;
scanf(“%d”, &x);
//goi ham tim kiem tuyen tinh
int i=timKiemTuyenTinh(a,n,x);
//neu khong tim thay
if (i==-1)
printf(”Khong tim thay %d trong day so”,x);
else
printf(“Tim thay %d o vi tri %d trong day so”,x,i);
//dung man hinh de xem ket qua
getch();
break ;
case 3 :
//goi ham sap xep chon
break ;
case 4 :
//goi ham sap xep doi cho truc tiep
break ;
case 5 :
//goi ham sap xep noi bot
break ;
case 6 :
//goi ham sap xep chen
break ;
case 7 :
//goi ham Shell Sort
break ;
case 8 :
//goi ham Quick Sort
break ;
case 9:
//goi ham tim kiem nhi phan
break;
case 10:
//goi ham hien thi day so
break;
default :
chon=0 ;
}
}while (chon);
}
Phn còn li sinh viên t cài đặt! Mi thc mc email v: vanthienhoang@yahoo.com.vn
