✨Cây đỏ đen

Cây đỏ đen

Cây đỏ đen (tiếng Anh: red-black tree) là một dạng cây tìm kiếm nhị phân tự cân bằng, một cấu trúc dữ liệu được sử dụng trong khoa học máy tính. Cấu trúc ban đầu của nó được đưa ra vào năm 1972 bởi Rudolf Bayer. Ông gọi chúng là các "B-cây cân bằng" còn tên hiện nay được đưa ra từ 1978 bởi Leo J. Guibas và Robert Sedgewick. Nó là cấu trúc phức tạp nhưng cho kết quả tốt về thời gian trong trường hợp xấu nhất. Các phép toán trên chúng như tìm kiếm (search), chèn (insert), và xóa (delete) trong thời gian O (log n), trong đó n là số các phần tử của cây.

Thuật ngữ

Một cây đỏ-đen là một cây nhị phân, là một cấu trúc dữ liệu trong khoa học máy tính để tổ chức các thành phần dữ liệu có thể so sánh, chẳng hạn các số. Trong cây nhị phân các thành phần dữ liệu được đưa vào các nút (node). Trong các nút có một nút nằm ở vị trí khởi đầu không là con của nút nào được gọi là gốc. Các nút khác đều là con của một nút nào đó và có không quá hai con. Từ nút gốc có một đường đi duy nhất đến mỗi nút khác trên cây.

Các nút không có con được gọi là lá (leaf node). Trong cây đỏ đen, các lá được gán giả là null; nghĩa là chúng không chứa bất kỳ dữ liệu nào.

Các cây tìm kiếm nhị phân, bao gồm cả cây đỏ-đen, thỏa mãn tính chất: mỗi nút được gán một giá trị sao cho giá trị trên mỗi nút nhỏ hơn hoặc bằng tất cả các giá trị trên các nút thuộc cây con phải và lớn hơn các giá trị nằm trên cây con trái. Điều đó làm cho quá trình tìm kiếm nhanh hơn.

Thuận lợi khi sử dụng

Các cây đỏ đen cùng với các cây AVL, thường đảm bảo một thời gian tốt nhất trong trường hợp xấu nhất cho các phép toán chèn (insertion), xóa (deletion),và tìm kiếm (search)..

Các cây đỏ-đen là một đồng cấu của các cây 2-3-4. Ngược lại, cho một cây 2-3-4, có ít nhất một cây đỏ-đen với các thầnh phần dữ liệu theo đúng thứ tự ấy. Các phép chèn và xóa trên cây 2-3-4 cũng tương đương với đổi màu và quay trong cây đỏ đen. Điều này làm cho các cây 2-3-4 có một công cụ quan trọng tương đương lôgic với cây đỏ-đen. Do đó các giải thuật trên các cây 2-3-4 tuy có trước cây đỏ-đen nhưng thường ít được dùng hơn cây đỏ đen.

Các tính chất

nhỏ|phải|Ví dụ một cây đỏ-đen

Mỗi nút của cây đỏ-đen có thuộc tính "màu" nhận một trong hai giá trị "đỏ" hoặc "đen". Ngoài ra:

Một nút hoặc là đỏ hoặc là đen.

Gốc là đen.

Tất cả các lá (NULL) là đen.

Cả hai con của mọi nút đỏ là đen. (và suy ra mọi nút đỏ có nút cha là đen)

Tất cả các đường đi từ một nút bất kỳ tới các lá có số nút đen bằng nhau.

Tính chất 5 còn được gọi là tính chất "cân bằng đen". Số các nút đen trên một đường đi từ gốc tới mỗi lá được gọi là độ dài đen của đường đi đó. Trong bài này chỉ xét các đường đi từ gốc tới các lá nên ta sẽ gọi tắt các đường đi như vậy là đường đi. Sức mạnh của cây đỏ đen nằm trong các tính chất trên. Từ các tính chất này suy ra trong các đường đi từ gốc tới các lá đường đi dài nhất không vượt quá hai lần đường đi ngắn nhất. Do đó cây đỏ đen là gần cân bằng. Vì các thuật toán chèn, xóa, tìm kiếm trong trường hợp xấu nhất đều tỷ lệ với chiều cao của cây nên cây đỏ đen rất hiệu quả trong các trường hợp xấu nhất,không giống như cây tìm kiếm nhị phân thông thường.

Để thấy rõ sức mạnh này, ta chú ý rằng không có đường đi nào từ gôc tới một lá chứa hai nút đỏ liền nhau (theo tính chất 4). Do đó trên mỗi đường số nút đỏ không nhiều hơn số nút đen. Đường đi ngắn nhất là đường đi chỉ có nút đen, đường đi dài nhất có thể là đường đi xen kẽ giữa các nút đỏ và đen. Theo tính chất 5, số các nút đen trên hai đường đi đó bằng nhau, và do đó đường đi dài nhất không vượt quá hai lần đường đi ngắn nhất.

Trong nhiều biểu diễn của dữ liệu cây, có thể có các nút chỉ có một con và có các lá có chứa dữ liệu. Tuy nhiên có thể biểu diễn cây đỏ đen ta có một chút thay đổi mà không làm thay đổi tính chất cơ bản của cây và độ phức tạp của các thuật toán. Với mục đích này, ta đưa thêm các lá null vào làm con phải hoặc con trái hoặc cả hai của những nút không có chúng, các lá này không chứa dữ liệu mà chỉ làm nhiệm vụ thông báo rằng tại đây cây đã kết thúc, như hình vẽ ở trên. Việc thêm các nút này làm cho tất cả các nút trong của cây đều chứa dữ liệu và có hai con, hay khác đi cây đỏ đen cùng với các lá null là cây nhị phân đầy dủ. Khi đó số các "lá null" nhiều hơn số các nút chứa dữ liệu của cây một lá.

Một số người định nghĩa cây đỏ đen bằng cách gán màu đỏ đen cho các cạnh chứ không phải các nút. Tuy nhiên điều đó không tạo nên sự khác biệt. Khi ấy màu của mỗi nút tương ứng với màu của cạnh nối nó với nút cha.

Các phép toán trên cây đỏ đen

Có thể áp dụng ngay các phép chèn, xóa trong cây tìm kiếm nhị phân vào cây đỏ đen mà không cần sửa chữa gì vì cây đỏ đen là trường hợp riêng của cây tìm kiếm nhị phân. Tuy nhiên, khi đó có thể có một số tính chất trong định nghĩa của cây đỏ đen sẽ bị vi phạm. Việc khôi phục các tính chất đỏ đen sẽ cần một số nhỏ cỡ O(log n) hoặc trung bình chỉ O(1) các phép đổi màu (tốn rất ít thời gian) và không quá ba phép quay cho phép xóa, hai cho phép chèn. Toàn bộ các giải thuật chèn và xóa có độ phức tạp thời gian cỡ O(log n).

Phép chèn

Phép chèn bắt đầu bằng việc bổ sung một nút như trong cây tìm kiếm nhị phân bình thường và gán cho nó màu đỏ. Ta xem xét để bảo toàn tính chất đỏ đen từ các nút lân cận với nút mới bổ sung. Thuật ngữ nút chú bác sẽ dùng để chỉ nút anh (hoặc em) với nút cha của nút đó như trong cây phả hệ. Chú ý rằng:

  • Tính chất 3 (Tất cả các lá -là các nút null là đen) giữ nguyên.
  • Tính chất 4 (Cả hai con của nút đỏ là đen) nếu bị thay đổi chỉ bởi việc thêm một nút đỏ có thể sửa bằng cách gán màu đen cho một nút đỏ hoặc một phép quay.
  • Tính chất 5 (Tất cả các đường đi từ gôc tới các lá có cùng một số nút đen) nếu bị thay đổi chỉ bởi việc thêm một nút đỏ có thể sửa bằng cách gán màu đen cho một nút đỏ hoặc một phép quay.

: Chú ý: Nhãn N sẽ dùng để chỉ nút đang chèn vào, P chỉ nút cha của N, G chỉ ông của N, và U chỉ chú bác của N. Nhớ rằng,giữa các trường hợp, vai trò và nhãn của các nút có thể thay đổi còn trong cùng một trường hợp thì không.

Mỗi trường hợp được giới thiệu bằng một đoạn mã C. Nút chú bác và nút ông dễ dàng xác định nhờ các hàm sau:

struct node grandparent(struct node n) { return n->parent->parent; }

struct node uncle(struct node n) { if (n->parent == grandparent(n)->left) return grandparent(n)->right; else return grandparent(n)->left; }

Trường hợp 1: Nút mới thêm N ở tại gốc. Trong trường hợp này, gán lại màu đen cho N, để bảo toàn tính chất 2 (Gốc là đen). Vì mới chỉ bổ sung một nút, Tính chất 5 được bảo đảm vì mọi đường đi chỉ có một nút.

void insert_case1(struct node *n) { if (n->parent == NULL) n->color = BLACK; else insert_case2(n); }

Trường hợp 2: Nút cha P của nút mới thêm là đen, khi đó Tính chất 4 (Cả hai nút con của nút đỏ là đen) không bị vi phạm vì nút mới thêm có hai con là "null' là đen. Tính chất 5 cũng không vi phạm vì nút mới thêm là đỏ không ẩnh hưởng tới số nút đen trên tất cả đường đi.

void insert_case2(struct node n) { if (n->parent->color == BLACK) return; / Tree is still valid */ else insert_case3(n); }

: Chú ý: Trong trường hợp tiếp theo nếu N có ông là nút G, vì nếu cha P là đỏ và P không ở gốc thì G là đen. Như vậy, N cũng có chú bác là U, mặc dù nó có thể là lá trong trường hợp thứ tư và thứ năm.

void insert_case3(struct node *n) { if (uncle(n)!= NULL && uncle(n)->color == RED) { n->parent->color = BLACK; uncle(n)->color = BLACK; grandparent(n)->color = RED; insert_case1(grandparent(n)); } else insert_case4(n); }

: Chú ý: Trong các trường hợp tiếp theo, giả sử rằng nút cha P là con trái của cha của nó. Nếu nó là con phải, leftright đổi chỗ cho nhau trong cases 4 and 5.

void insert_case4(struct node *n) { if (n = = n->parent->right && n->parent = = grandparent(n)->left) { rotate_left(n->parent); n = n->left; } else if (n = = n->parent->left && n->parent = = grandparent(n)->right) { rotate_right(n->parent); n = n->right; } insert_case5(n); }

void insert_case5(struct node n) { n->parent->color = BLACK; grandparent(n)->color = RED; if (n == n->parent->left && n->parent == grandparent(n)->left) { rotate_right(grandparent(n)); } else { / Here, n == n->parent->right && n->parent == grandparent(n)->right */ rotate_left(grandparent(n)); } }

Phép xóa

Trong cây tìm kiếm nhị phân bình thường khi xóa một nút có cả hai con (không là lá null), ta tìm phần tử lớn nhất trong cây con trái hoặc phần tử nhỏ nhất trong cây con phải, chuyển giá trị của nó vào nút đang muốn xóa (xem Cây tìm kiếm nhị phân). Khi đó chúng ta xóa đi nút đã được copy giá trị, nút này có ít hơn hai con (không là lá null). Vì việc copy giá trị không làm mất tính chất đỏ đen nên không cần phải sửa chữa gì cho thao tác này. Việc này chỉ đặt ra khi xóa các nút có nhiều nhất một con (không là lá null).

Chúng ta sẽ thảo luận về việc xóa một nút có nhiều nhất một con (không là lá null).

Nếu ta xóa một nút đỏ, ta có thể chắc chắn rằng con của nó là nút đen. Tất cả các đường đi đi qua nút bị xóa chỉ đơn giản bớt đi một nút đỏ do đó tính chất 5 không thay đổi. Ngoài ra, cả nút cha và nút con của nút bị xóa đều là nút đen, do đó tính chất 3 và 4 vẫn giữa nguyên.. Một trường hợp đơn giản khác là khi xóa một nút đen chỉ có một con là nút đỏ. Khi xóa nút đó các tính chất 4 và 5 bị phá vỡ, nhưng nếu gán lại màu cho nút con là đen thì chúng lại được khôi phục.

Trường hợp phức tạp xảy ra khi cả nút bị xóa và nút con của nó đều là đen. Chúng ta sẽ bắt đầu bằng việc thay nút bị xóa bằng nút con của nó. Chúng ta sẽ gọi nút con này (trong vị trí mới của nó là N, và anh em với nó (con khác của nút cha mới) là S. Tiếp theo ta vẫn dùng P chỉ cha mới của N, SL chỉ con trái của S, và SR chỉ con phải của S (chúng tồn tại vì S không thể là lá).

: Chú ý: Giữa các trường hợp khác nhau, vai trò và nhãn của các nút có thể thay đổi, nhưng trong một trường hợp mọi nhãn giữ vai trò không thay đổi. Trong hình vẽ các màu đỏ đen được thể hiện khi màu của nút đã rõ ràng, màu trắng biểu thị một màu chưa rõ (hoặc đỏ hoặc đen).

Chúng ta sẽ sử dụng hàm sau tìm người anh em của N':

struct node sibling(struct node n) { if (n = = n->parent->left) return n->parent->right; else return n->parent->left; }

: Chú ý: Tất nhiên, chúng ta cần hoàn chỉnh các lá null sau mọi phép thay đổi. Nếu nút bị xóa không có con N khác "lá null", dễ dàng thấy rằng các tính chất được thỏa mãn. Còn nếu N là một "lá nulll", có thể sửa chữa lược đồ (hoặc code) để trong tất cảc các trường hợp các tính chất được thỏa mãn.

Trước mỗi bước ta có thể dùng hàm (function) replace_node thay thế nút con child vào vị trí của nút bị xóa trên cây. Để thuận tiện các đoạn code trong mục này quy ước rằng các "lá null" được biểu diễn bằng các đối tượng nút thực sự khác biệt một chút với NULL (code trong phép chèn có biểu diễn không nư vậy).

void delete_one_child(struct node n) { / Giả thiết: n có ít nhất một nút con null / struct node child = is_leaf(n->right) ? n->left: n->right; replace_node(n, child); if (n->color == BLACK) { if (child->color == RED) child->color = BLACK; else delete_case1(child); } free(n); }

: Ghi chú: Nếu N là "lá nul" và ta khong muốn biểu diễn các "lá null" bằng các đối tượng nút thực, ta có thể sửa giải thuật bằng cách trước hết gọi delete_case1() trên cha của nó (nghĩa là nút bị xóa n trong đoạn code trên) rồi sau đó mới xóa nó. Ta có thể làm như vậy vì cha của nó là đen, do đó có diễn biến như với "lá null" (một số người gọi là "lá ảo", "lá ma"). Ta cũng có thể xóa nó khỏi cuối của n và sẽ khôi phục lại sau tất cả các phép toán.

Nếu cả N và gốc ban đầu của nó là đen thì sau khi xóa các đường qua "N" giảm bớt một nút đen. Do đó vi phạm Tính chất 5, cây cần phải cân bằng lại. Có các trường hợp sau:

Trường hợp 1

Trường hợp 1: N là gốc mới. Trong trường hợp này chúng ta dừng lại. Ta đã giải phóng một nút đen khỏi mọi đường đi và gôc mới lại là đen. Không tính chất nào bị vi phạm.

void delete_case1(struct node *n) { if (n->parent == NULL) return; else delete_case2(n); }

: Chú ý: Trong các trường hợp 2, 5, và 6, ta quy ước N là con trái của cha P. Nếu no là con phải, leftright sẽ tráo đổi cho nhau. Tuy nhiên code ví dụ làm cho cả hai trường hợp.

void delete_case2(struct node *n) { if (sibling(n)->color == RED) { n->parent->color = RED; sibling(n)->color = BLACK; if (n == n->parent->left) rotate_left(n->parent); else rotate_right(n->parent); } delete_case3(n); }

void delete_case3(struct node *n) { if (n->parent->color == BLACK && sibling(n)->color == BLACK && sibling(n)->left->color == BLACK && sibling(n)->right->color == BLACK) { sibling(n)->color = RED; delete_case1(n->parent); } else delete_case4(n); }

void delete_case4(struct node *n) { if (n->parent->color == RED && sibling(n)->color == BLACK && sibling(n)->left->color == BLACK && sibling(n)->right->color == BLACK) { sibling(n)->color = RED; n->parent->color = BLACK; } else delete_case5(n); }

void delete_case5(struct node *n) { if (n == n->parent->left && sibling(n)->color == BLACK && sibling(n)->left->color == RED && sibling(n)->right->color == BLACK) { sibling(n)->color = RED; sibling(n)->left->color = BLACK; rotate_right(sibling(n)); } else if (n == n->parent->right && sibling(n)->color == BLACK && sibling(n)->right->color == RED && sibling(n)->left->color == BLACK) { sibling(n)->color = RED; sibling(n)->right->color = BLACK; rotate_left(sibling(n)); } delete_case6(n); }

void delete_case6(struct node n) { sibling(n)->color = n->parent->color; n->parent->color = BLACK; if (n == n->parent->left) { / Here, sibling(n)->right->color == RED / sibling(n)->right->color = BLACK; rotate_left(n->parent); } else { / Here, sibling(n)->left->color == RED */ sibling(n)->left->color = BLACK; rotate_right(n->parent); } }

Nhắc lại rằng các hàm này có lời gọi đệ quy. Thêm nữa lời gọi không đệ quy sẽ được goi sau một phép quay, do đó số lần thực hiện các phép quay là không đổi (không quá 3).

👁️ 1 | 🔗 | 💖 | ✨ | 🌍 | ⌚
**Cây đỏ đen** (tiếng Anh: _red-black tree_) là một dạng cây tìm kiếm nhị phân tự cân bằng, một cấu trúc dữ liệu được sử dụng trong khoa học máy tính. Cấu trúc ban đầu
**Trèo cây trán đen**, tên khoa học **_Sitta frontalis_**, là một loài chim trong họ Sittidae. Chúng có thể tìm thấy được ở Pakistan, Ấn Độ, Sri Lanka đến Trung Quốc và Indonesia. ## Hình
**Trèo cây lưng đen**, tên khoa học **_Sitta formosa_**, là một loài chim trong họ Sittidae.
Trong khoa học máy tính, **cây 2-3-4** là cây nhiều nhánh mà mỗi nút của nó có thể có đến bốn nút con và ba mục dữ liệu. Cây 2-3-4 là cây cân bằng giống
Trong khoa học máy tính, một **Cây AVL** là một cây tìm kiếm nhị phân tự cân bằng, và là cấu trúc dữ liệu đầu tiên có khả năng này. Trong một cây AVL, tại
phải|khung|Một cây có dán nhãn với 6 đỉnh và 5 cạnh **Cây** là khái niệm quan trọng trong lý thuyết đồ thị, cấu trúc dữ liệu và giải thuật. Cây là một đồ thị mà
Set 2 cây Bút kẻ viền định hình Môi Mày Đỏ + Đen phun xăm+ Bút kẻ viền Môi Mày chuyên dụng trong kỹ thuật phun xăm mày, tattoo, phẫu thuật,...+ Được nhiều chuyên gia
Trong khoa học máy tính, **Phép quay** trên các cây nhị phân là một phép biến đổi làm thay đổi vai trò cha con giữa 2 nút trên cây. Có hai phép quay là quay
**Cây tìm kiếm nhị phân** (viết tắt tiếng Anh: BST - _Binary Search Tree_) là một cấu trúc dữ liệu rất thuận lợi cho bài toán tìm kiếm. Mỗi cây tìm kiếm nhị phân đều
Sữa tắm gội toàn thân Malizia Bon Bons hương trái cây đỏ được chiết xuất từ những trái cây màu đỏ với công thức đặc biệt kết hợp giữa sữa tắm và dầu gội mang
Set 2 cây - Bút Chì xé Đỏ + Đen cứng Đá Sharpie vẽ Mày Môi Mí mắt phun xăm- Bám lâu, lôi trôi, chống thấm nước và mồ hôi. Rất dễ sử dụng, các
https://www.lazada.vn/shop/sieu-thi-truc-tuyen-viet-nam/ Cây Đo Nhiệt Kế. Mua Ngay Nhiệt Kế Hồng Ngoại Trẻ Em, Đo Trán Đo Tai Thông tin chi tiết sản phẩmBẢO HÀNH 1 ĐỔI 1 - AN TÂM MUA HÀNG Với nhiều ưu
Chì xé cứng Đá vẽ Mày Môi Mí mắt phun xăm - Bám lâu, lôi trôi, chống thấm nước và mồ hôi.- Rất dễ sử dụng, các bạn đặt góc chéo rồi đi theo chiều
Giới thiệu Kéo cắt tóc KASHO ĐỎ - ĐEN Mô tả sản phẩm :## Tên sản phẩm : KÉO CẮT TÓC KASHO ĐỎ - ĐEN - Xuất xứ: Nhật Bản - Kích thước: 6 inches
Thông tin chi tiết Bao Vợt Cầu Lông LIGHTSPORT Đỏ Đen - Với phong cách thiết kế hiện đại, trẻ trung, cá tính kết hợp cùng màu sắc nổi bật, mạnh mẽ chắc chắn chiếc
nhỏ|200x200px|Cây sự sống trên thiên đường - Hình minh họa thế kỷ 15 **Cây sự sống** (tiếng Hebrew: עֵץ הַחַיִּים - _Ec ha-Chajim_) là cây trong vườn địa đàng theo Kinh Thánh, sinh trái ăn
**Cây trồng biến đổi gen** (Genetically Modified Crop - **GMC**) là loại cây trồng được lai tạo ra bằng cách sử dụng các kỹ thuật của công nghệ sinh học hiện đại, hay còn gọi
thumb|right|Phụ nữ trong độ tuổi sinh sản và trẻ em dưới 2 tuổi cần cải thiện tình trạng dinh dưỡng bằng cách ăn thực phẩm tốt cho sức khỏe Trong dinh dưỡng, **chế độ ăn
Dưới đây là **danh sách các cây di sản ở Việt Nam** xếp theo thể loại và tuổi. Danh hiệu Cây Di sản Việt Nam được Hội Bảo vệ Thiên nhiên và Môi trường Việt
**Trèo cây** là tên gọi chung của một nhóm các loài chim dạng sẻ nhỏ thuộc chi **_Sitta_** trong họ **Sittidae**, có hình thái đặc trưng là đầu to, đuôi ngắn, mỏ và bàn chân
Xạ ĐenHòa Bình Cả Lá Và Thân 1kg - SP CTY Thảo Dược SỐ 1CâyXạ đenlà gì ?Giải thích từXạ:Trong tiếng mường xạ có nghĩa là GanĐen: chỉ màu sắc của cây Th.uốcnày ” Thân
phải|Đền Cây Nuốt **Đền Trapeang Ropeak**, nơi thờ thần Indra - là một trong nhóm 7 ngôi đền còn nguyên vẹn trong quần thể cố đô cố đô Sambor Prei Kuk được xây dựng vào
**Cây di sản** là những cây thân gỗ, đa phần là cây cổ thụ, có từ lâu đời và có giá trị lớn về văn hóa, giáo dục, lịch sử, xã hội, sinh thái, du
MÔ TẢ SẢN PHẨMSET 3 chiếc Đèn LED quang phổ toàn phần trồng câySố lượng: 3 chiếc Phù hợp với các loài cây nhỏ. Đèn led thủy canh này có thể nhanh chóng cải thiện
**Trạng nguyên** hay **nhất phẩm hồng** (danh pháp hai phần: **_Euphorbia pulcherrima_**) _(Euphorbia pulcherrima)_ là một loài thực vật có tính thương mại quan trọng của họ spurge đa dạng (Euphorbiaceae). Là một giống bản
Nghệ đen được dùng làm thuốc trong đông y với tên gọi là nga truật. Thảo dược này nổi tiếng với tác dụng chữa đau dạ dày, ăn không tiêu, tắc kinh, nôn trớ ở
Cọ trang điểm cán gỗ cao cấp 11 cây và Son Agapan Pit A Pat dạng thỏi: I. Cọ trang điểm cán gỗ cao cấp 11 cây: Trang điểm là cách đơn giản nhất giúp
Cọ trang điểm cán gỗ cao cấp 11 cây và Son Agapan Pit A Pat dạng thỏi: I. Cọ trang điểm cán gỗ cao cấp 11 cây: Trang điểm là cách đơn giản nhất giúp
Cọ trang điểm cán gỗ cao cấp 11 cây và Son Agapan Pit A Pat dạng thỏi: I. Cọ trang điểm cán gỗ cao cấp 11 cây: Trang điểm là cách đơn giản nhất giúp
Cọ trang điểm cán gỗ cao cấp 11 cây và Son Agapan Pit A Pat dạng thỏi: I. Cọ trang điểm cán gỗ cao cấp 11 cây: Trang điểm là cách đơn giản nhất giúp
Cọ trang điểm cán gỗ cao cấp 11 cây và Son Agapan Pit A Pat dạng thỏi: I. Cọ trang điểm cán gỗ cao cấp 11 cây: Trang điểm là cách đơn giản nhất giúp
**Rau dền**, là tên gọi chung để chỉ các loài trong **Chi Dền** (danh pháp khoa học: **_Amaranthus_**, bao gồm cả các danh pháp liên quan tới _Acanthochiton_, _Acnida_, _Montelia_) do ở Việt Nam thường
thumb|Những quả mâm xôi chín đỏ. **Mâm xôi đỏ** hay **Phúc bồn tử** () là một loại quả ăn được trong vô số loài thưc vật trong chi Mâm xôi thuộc họ Dâu, hầu hết
Một bài viết bị phá hoại trên Wikipedia. Tiết đoạn ở bên trái là phiên bản bình thường không bị tổn hại; còn ở bên phải là phiên bản bị [[wikipedia:Phá hoại|phá hoại.]] Sự tin
Sản phẩm Cà Gai Leo Xạ Đen giúp bổ gan, bảo vệ gan, thanh nhiệt, giải độc, nhuận gan, lợi mật. Tăng cường chức năng đào thải độc tố cho gan, hạn chế tổn thương
XẠ ĐEN KHÔ Cây xạ đen còn được gọi là cây dây gối, được trồng nhiều ở Hòa Bình do khí hậu nơi đây thích hợp nhất. Khi phơi khô lá xạ đen có mùi
Cây xạ đen là một trong những sản phẩm quý hiếm có tác dụng hỗ trợ cho người bị nan y, trong đó đặc biệt là ung thư, iểu đường, uyết áp. Quá trình trồng
**Sao đen** (danh pháp hai phần: **_Hopea odorata_**) là loài thực vật thuộc chi Sao, họ Dầu. ## Phân bố Loài này có ở Ấn Độ (Tây Bengal, quần đảo Andaman), Bangladesh, Campuchia, Lào, Malaysia
phải|Đền chính **Đền sư tử Yeai Pourn **- là ngôi đền nằm trong khu phức hợp di tích trong cố đô Sambor Prei Kuk được xây dựng vào thế kỷ 7, nguyên là kinh đô
**Cây bình rượu** (cũng gọi là cây bình nước) có danh pháp: **_Nepenthes rafflesiana_**, là một loài của chi nắp ấm, sống trên cạn, khá phổ biến ở nhiều vùng nhiệt đới của Borneo, Sumatra,
nhỏ|phải|Nai Ấn Độ **Hệ động vật Ấn Độ** phản ánh về các quần thể động vật tại Ấn Độ cấu thành hệ động vật của quốc gia này. Hệ động vật Ấn Độ rất đa
9 CÔNG DỤNG CỦA CÂY MẬT NHÂN: 1. Mật nhân được dùng như một dược li ệu giúp cải thiện chức năng sinh lý ở nam giới. 2. Hỗ trợ đi ều tr ị chứng
9 CÔNG DỤNG CỦA CÂY MẬT NHÂN:1. Mật nhân được dùng như một dược li ệu giúp cải thiện chức năng sinh lý ở nam giới.2. Hỗ trợ đi ều tr ị chứng khí hư,
9 CÔNG DỤNG CỦA CÂY MẬT NHÂN:1. Mật nhân được dùng như một dược li ệu giúp cải thiện chức năng sinh lý ở nam giới.2. Hỗ trợ đi ều tr ị chứng khí hư,
9 CÔNG DỤNG CỦA CÂY MẬT NHÂN:1. Mật nhân được dùng như một dược li ệu giúp cải thiện chức năng sinh lý ở nam giới.2. Hỗ trợ đi ều tr ị chứng khí hư,
9 CÔNG DỤNG CỦA CÂY MẬT NHÂN:1. Mật nhân được dùng như một dược li ệu giúp cải thiện chức năng sinh lý ở nam giới.2. Hỗ trợ đi ều tr ị chứng khí hư,
9 CÔNG DỤNG CỦA CÂY MẬT NHÂN:1. Mật nhân được dùng như một dược li ệu giúp cải thiện chức năng sinh lý ở nam giới.2. Hỗ trợ đi ều tr ị chứng khí hư,
9 CÔNG DỤNG CỦA CÂY MẬT NHÂN:1. Mật nhân được dùng như một dược li ệu giúp cải thiện chức năng sinh lý ở nam giới.2. Hỗ trợ đi ều tr ị chứng khí hư,
9 CÔNG DỤNG CỦA CÂY MẬT NHÂN:1. Mật nhân được dùng như một dược li ệu giúp cải thiện chức năng sinh lý ở nam giới.2. Hỗ trợ đi ều tr ị chứng khí hư,
thumb|Một bóng đèn LED 230V, đui đèn cỡ trung bình (E27), công suất 10 [[Watt, 806 Lumen]] thumb|Một bóng đèn LED dây tóc có điện áp 230V với đui đèn E27. Sợi dây tóc bóng đèn trong