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

Cơ sở dữ liệu và giải thuật - Thầy Vũ Song Tùng

64 1,1K 4

Đ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 64
Dung lượng 1,96 MB

Nội dung

Cơ sở dữ liệu và giải thuật - Thầy Vũ Song Tùng

Trang 1

VÀ GIẢI THUẬT

Vũ Song Tùng

1

Trang 4

I Giới thiệu chung

• Lập trình hàm

– Chia các giai đoạn của chương trình vào các hàm

– Thể hiện những đoạn mã tương tự trong một hàm

– Ưu điểm

• Dễ quản lý

• Tiết kiệm dung lượng chương trình

Trang 5

5

• Lập trình hướng đối tượng

– Trừu tượng hóa các thành phần của chương trình

– Đặc điểm

• Tính đóng gói – các thuộc tính của một thành phần và các hàm

xử lý các thuộc tính đó được định nghĩa trong cùng một khối

• Tính đa hình – cho phép tạo ra nhiều hình thái của một loại thành phần

• Tính kế thừa – cho phép sử dụng lại các định nghĩa đã có của một thành phần để tạo ra một thành phần mới

Trang 6

I Giới thiệu chung

• Các quy ước

Các kiểu dữ liệu Mô tả

ℝ, ℕ, ℤ Tập các số thực, nguyên và nguyên dương

𝐀𝐫𝐫𝐚𝐲 𝓁 𝓇 𝐨𝐟 𝑇𝑦𝑝𝑒 Mảng chứa 𝓇 – 𝓁 + 1 phần tử kiểu T

𝐒𝐞𝐪𝐮𝐞𝐧𝐜𝐞 𝐨𝐟 𝑇𝑦𝑝𝑒 Dãy

Trang 8

I Giới thiệu chung

Trang 9

Lấy nội dung trong con trỏ ∗ 𝑝

Truy cập thành viên của con trỏ 𝑝 → 𝑐

Trang 10

I Giới thiệu chung

• Hàm và thủ tục

𝐩𝐫𝐨𝐜𝐞𝐝𝐮𝐫𝐞 Power 𝑥 ∶ ℝ; 𝑛 ∶ ℤ; 𝐯𝐚𝐫 𝑟 ∶ ℝ

𝑟 = 1 ∶ ℝ 𝐟𝐨𝐫 𝑖 ≔ 1 𝐭𝐨 𝑛 𝐝𝐨

𝑟 ≔ 𝑟 ∗ 𝑥

𝐟𝐮𝐧𝐜𝐭𝐢𝐨𝐧 Power 𝑥 ∶ ℝ; 𝑛 ∶ ℤ ∶ ℝ

𝐢𝐟 𝑛 = 0 𝐭𝐡𝐞𝐧 𝐫𝐞𝐭𝐮𝐫𝐧 1 𝐞𝐥𝐬𝐞 𝐫𝐞𝐭𝐮𝐫𝐧 𝑥 ∗ Power 𝑥, 𝑛 − 1

Trang 11

𝐟𝐮𝐧𝐜𝐭𝐢𝐨𝐧 add 𝑐 ∶ 𝐶𝑜𝑚𝑝𝑙𝑒𝑥 ∶ 𝐶𝑜𝑚𝑝𝑙𝑒𝑥

𝐫𝐞𝐭𝐮𝐫𝐧 𝐶𝑜𝑚𝑝𝑙𝑒𝑥 𝑟 + 𝑐 𝑟, 𝑖 + 𝑐 𝑖

Trang 12

I Giới thiệu chung

Trang 14

I Giới thiệu chung

• Giải thuật đệ quy

– Giải thuật gọi lại chính nó, gồm 2 thành phần:

• Điều kiện dừng đệ quy

• Gọi đệ quy

– Áp dụng giải thuật đệ quy khiến cho thuật toán trở nên mạch lạc

Trang 16

II Danh sách tuyến tính

Ngăn xếp

Hàng đợi

Danh sách liên kết

Trang 18

II Danh sách tuyến tính

Trang 19

19

• Dãy các phần tử được thêm vào (enqueue)

và lấy ra (dequeue) tại hai đầu khác nhau

của dãy

𝑄 = 𝑒𝑓, 𝑒𝑓+1, … , 𝑒𝑟

𝑒 ↦ 𝑄 ⇒ 𝑄 ≔ 𝑒𝑓, 𝑒𝑓+1, … , 𝑒𝑟, 𝑒𝑟+1

𝑒 ↤ 𝑄 ⇒ 𝑒, 𝑄 ≔ 𝑒𝑓, 𝑒𝑓+1, … , 𝑒𝑟

Trang 20

II Danh sách tuyến tính

Trang 21

21

• Danh sách liên kết 2 chiều

• Dãy các phần tử liên kết với phần tử phía sau (next)

và phía trước (prev) trong dãy

𝐿 = 𝑓𝑖𝑟𝑠𝑡, … , 𝑝, 𝑞, … , 𝑙𝑎𝑠𝑡

𝑝 → 𝑛𝑒𝑥𝑡 = 𝑞

𝑞 → 𝑝𝑟𝑒𝑣 = 𝑝

Trang 22

II Danh sách tuyến tính

Trang 24

II Danh sách tuyến tính

Trang 25

𝐩𝐫𝐨𝐜𝐞𝐝𝐮𝐫𝐞 pushBegin 𝑒 ∶ 𝑇𝑦𝑝𝑒 𝑕 insertAfter newItem 𝑒

𝐩𝐫𝐨𝐜𝐞𝐝𝐮𝐫𝐞 pushBegin 𝑒 ∶ 𝑇𝑦𝑝𝑒 𝑕 𝑝𝑟𝑒𝑣 → insertAfter newItem 𝑒

𝐩𝐫𝐨𝐜𝐞𝐝𝐮𝐫𝐞 popBegin 𝑝 ≔ 𝑕 𝑛𝑒𝑥𝑡; 𝑕 remove 𝑝

𝐩𝐫𝐨𝐜𝐞𝐝𝐮𝐫𝐞 popEnd 𝑝 ≔ 𝑕 𝑝𝑟𝑒𝑣; 𝑕 remove 𝑝

𝐩𝐫𝐨𝐜𝐞𝐝𝐮𝐫𝐞 removeAll 𝑕 makeEmpty

Trang 26

III Cây

Các khái niệm

Cây nhị phân

Một vài ứng dụng

Trang 28

A

D

B

C Cây zíc-zắc

Trang 29

29

• Mô hình lưu trữ

• Mỗi nút trên cây được coi là một cây con gồm một trường chứa dữ liệu (info) và hai địa chỉ liên kết với cây con trái (left) và phải (right)

Trang 31

31

• Biểu diễn cây tổng quát

• Con đầu tiên (First Child)  left

• Em liền kề (Next Sibling)  right

Trang 33

33

• Cây nhị phân tìm kiếm

• Tất cả các nút của cây con trái phải nhỏ hơn gốc và nhỏ hơn tất cả các nút của cây con phải

• Sử dụng trong các danh sách thường xuyên phải xử l{ các thao tác thêm, xóa dữ liệu

Trang 35

35

• Đồ thị (graph) được xác định bằng tập các đỉnh (vertex) và tập các cung (edge) giữa các đỉnh

𝐺 = 𝑉, 𝐸

𝑒 = 𝑢, 𝑣 |𝑢,𝑣∈𝑉;𝑒∈𝐸

Trang 37

37

• Danh sách các cung (Edge List)

𝐺 ∶ 𝐿𝑖𝑠𝑡 𝐨𝐟 𝐸𝑑𝑔𝑒 𝐸𝑑𝑔𝑒 𝑢, 𝑣 ∶ 𝐏𝐨𝐢𝐧𝐭𝐞𝐫 𝐭𝐨 𝑉𝑒𝑟𝑡𝑒𝑥

Trang 43

43

• Kiểm tra kết nối giữa hai đỉnh (Connectedness)

• Tìm đường đi ngắn nhất giữa hai đỉnh

• Tìm chi phí thấp nhất (Min Cose Spanning Tree)

• Sắp xếp topo (Topological Sorting)

Trang 44

V Sắp xếp Các thuật toán đơn giản

Sắp xếp nhanh

Sắp xếp vun đống

Trang 58

VI Tìm kiếm

Tìm kiếm tuần tự

Tìm kiếm chia đôi

Cây nhị phân tìm kiếm

Trang 60

VI Tìm kiếm

• Tìm kiếm chia đôi (Binary Search)

• Áp dụng cho mảng đã được sắp xếp tăng dần

Trang 61

BST

Ngày đăng: 27/03/2014, 11:53

HÌNH ẢNH LIÊN QUAN

Đồ thị - Cơ sở dữ liệu và giải thuật - Thầy Vũ Song Tùng
th ị (Trang 2)

TỪ KHÓA LIÊN QUAN

TÀI LIỆU CÙNG NGƯỜI DÙNG

TÀI LIỆU LIÊN QUAN

w