TAILIEUCHUNG - Binary Search (Tìm kiếm nhị phân)

Thuật toán tìm kiếm nhị fân sử dụng kĩ thuật chia để trị để tìm kiếm. Đầu tiên, fần tử tìm kiếm được so sánh với phần tử giữa của list. Nếu fần tử tìm kiếm bé hơn phần tử giữa, giới hạn tìm kiệm lại về nửa đầu của list. Nếu không, tìm kiếm nửa sau của list. | Binary Search (Tìm kiếm nhị fân) Thuật toán tìm kiếm nhị fân sử dụng kĩ thuật chia để trị để tìm kiếm. Đầu tiên, fần tử tìm kiếm được so sánh với phần tử giữa của list. Nếu fần tử tìm kiếm bé hơn phần tử giữa, giới hạn tìm kiệm lại về nửa đầu của list. Nếu không, tìm kiếm nửa sau của list. Binary Search Tìm kiếm nhị fân là 1 kỹ thuật mạnh đáng kinh ngạc để tìm kiếm trong 1 list đã được sắp xếp. Nó quen thuộc với mọi người sử dụng danh bạ điện thoại. Minh họa Tìm kiếm với key = 78: 1 3 5 6 10 11 14 25 26 40 41 78 - (Xem hình minh hoạ trong slide tiếng anh) - 4 phép toán cần thiết để tìm ra phần tử fù hợp. - Thử tính xem phải dùng bao nhiêu phép toán nếu sử dụng tìm kiếm tuần tự? Ví dụ Đầu tiên so sánh 78 với fần tử giữa của list L[5] là 11. 78 > 11. Vì vậy ta giới hạn lại tìm kiếm L[6 11] như hình minh hoạ. Binary Search Code // target là số cần tìm, size là kích thước list Int binSearch (int List[], int Target, int Size) { int Mid, Lo = 0, Hi = Size –1; while( Lo 11. Vì vậy ta giới hạn lại tìm kiếm L[6 11] như hình minh hoạ. Binary Search Code // target là số cần tìm, size là kích thước list Int binSearch (int List[], int Target, int Size) { int Mid, Lo = 0, Hi = Size –1; while( Lo #define NotFound (-1) typedef int ElementType; int BinarySearch(ElementType A[ ], ElementType X, int N ) { int Low, Mid, High; Low = 0; High = N -1; while( Low X ) High = Mid -1; else return Mid; /* Found */ } return NotFound; /* NotFound được định nghĩa = -1 */ } Chương trình test main( ) { static int A[ ] = { 1, 3, 5, 7, 9, 13, 15 }; int SizeofA = sizeof( A ) / sizeof( A[ 0 ] ); int i; for( i = 0; i High) .

TỪ KHÓA LIÊN QUAN
TAILIEUCHUNG - Chia sẻ tài liệu không giới hạn
Địa chỉ : 444 Hoang Hoa Tham, Hanoi, Viet Nam
Website : tailieuchung.com
Email : tailieuchung20@gmail.com
Tailieuchung.com là thư viện tài liệu trực tuyến, nơi chia sẽ trao đổi hàng triệu tài liệu như luận văn đồ án, sách, giáo trình, đề thi.
Chúng tôi không chịu trách nhiệm liên quan đến các vấn đề bản quyền nội dung tài liệu được thành viên tự nguyện đăng tải lên, nếu phát hiện thấy tài liệu xấu hoặc tài liệu có bản quyền xin hãy email cho chúng tôi.
Đã phát hiện trình chặn quảng cáo AdBlock
Trang web này phụ thuộc vào doanh thu từ số lần hiển thị quảng cáo để tồn tại. Vui lòng tắt trình chặn quảng cáo của bạn hoặc tạm dừng tính năng chặn quảng cáo cho trang web này.