Trong Khoa học máy tính, bài toán phát hiện chu trình hay tìm chu trình là bài tìm thuật toán tìm vòng lặp trong một chuỗi giá trị hàm.
Bất kỳ hàm nào ánh xạ một tập hữu hạn tới chính nó, và bất kỳ giá trị ban đầu trong , chuỗi các giá trị hàm
:
phải có một giá trị xuất hiện hai lần: có một số cặp i và j phân biệt sao cho . Khi điều này xảy ra, chuỗi tiếp tục chu trình một cách định kỳ, bằng cách lặp lại chuỗi giá trị từ tới . Tìm chu trình là bài toán tìm i và j khi biết và .
Rất nhiều thuật toán tìm chu trình nhanh và dùng ít bộ nhớ được biết. Thuật toán rùa và thỏ của Robert W.Floyd di chuyển hai con trỏ với vận tốc khác nhau qua chuỗi cho đến khi chúng cùng chỉ một giá trị. Lựa chọn khác, ta có thuật toán của Brent dựa trên ý tưởng tìm kiếm theo cấp số mũ. Cả hai thuật toán trên chỉ dùng một số lượng cố định bộ nhớ và tính giá trị hàm một lượng tỷ lệ thuận với khoảng cách tính từ xuất phát của chuỗi đến giá trị lặp đầu tiên. Các thuật toán khác đổi bộ nhớ lớn hơn để tính ít hơn số lần tính giá trị hàm.
Ứng dụng của phát hiện chu trình bao gồm thử nghiệm chất lượng của bộ sinh số giả ngẫu nhiên và hàm băm mật mã học, các thuật toán trong lý thuyết số tính toán, phát hiện vòng lặp vô hạn trong các chương trình máy tính và các cấu hình tuần hoàn trong tế bào tự động hóa.
Thí dụ
nhỏ|Một hàm từ và đến tập {0,1,2,3,4,5,6,7,8} và đồ thị hàm tương ứng
Hình bên cho biết một hàm ánh xạ tập tới chính nó. Nếu ta xuất phát từ và liên tục áp dụng hàm , ta sẽ được chuỗi sau
:
Chu trình trong chuỗi giá trị này là 6, 3, 1.
Định nghĩa
Gọi là tập hữu hạn bất kỳ, là hàm bất kỳ từ ánh xạ vào chính nó và là phần tử bất kỳ trong . Với bất kỳ , đặt . Gọi là chỉ số nhỏ nhất sao cho giá trị thường xuyên lặp lại vô hạn trong chuỗi giá trị và đặt (độ dài vòng lặp) là số nguyên dương nhỏ nhất sao cho . Bài toán phát hiện chu trình yêu cầu tìm hai giá trị và .
Ta có thể xét bài toán này bằng lý thuyết đồ thị, bằng cách xây một đồ thị hàm (một đồ thị có hướng mà mỗi đỉnh có một cung đi ra) trong đó mỗi đỉnh là một phần tử của S, và các cung đi ra ánh xạ phần tử giá trị hàm tương ứng, như hình trên.
Các thuật toán
Nếu input được đưa như một thủ tục con là để tìm f, bài toán có thể giải đơn giản dùng chỉ lần tính hàm, bằng cách tính chuỗi giá trị dùng một cấu trúc dữ liệu như bảng băm để lưu các giá trị này và kiểm tra xem các giá trị sau đã được lưu chưa. Tuy nhiên, độ phức tạp bộ nhớ tỉ lệ thuận với , lớn không cần thiết. Do đó nghiên cứu trong khu vực này tập trung vào hai mục tiêu: dùng ít bộ nhớ hơn thuật toán trên và tìm thuật toán con trỏ dùng ít số lần kiểm tra hơn.
Thuật toán rùa và thỏ của Floyd
thumb|upright=1.25|Thuật toán rùa và thỏ của Floyd, áp dụng với chuỗi 2, 0, 6, 3, 1, 6, 3, 1,...
Thuật toán tìm chu trình của Floyd là thuật toán con trỏ dùng hai con trỏ, di chuyển trên cùng một chuỗi với tốc độ khác nhau. Nó cũng được gọi là "thuật toán rùa và thỏ", dựa trên câu chuyện ngụ ngôn của Aesop.
Thuật toán được đặt tên theo Robert W. Floyd, người được công nhận bởi Donald Knuth. Tuy nhiên, thuật toán không xuất hiện trong các bài của Floyd, và do đó đây có thể là quy kết nhầm: Floyd mô tả các thuật toán liệt kê toàn bộ các chu trình đơn trong một đồ thị có hướng trong tờ nghiên cứu năm 1967, nhưng tờ báo đó không mô tả bài toán tìm chu trình với đồ thị hàm ở đây. Thậm chí, theo lời của Knuth (vào năm 1969), quy nó về Floyd mà không trích dẫn.
Yếu tố quan trọng trong thuật toán như sau. Nếu có một chu trình, thì, với bất kỳ và , , với là độ dài vòng lặp cần tìm và là vị trí của phần tử đầu tiên trong chu trình. Dựa trên đây, ta có thể chứng minh với một vài số khi và chỉ khi . Như vậy, thuật toán chỉ cần kiểm tra các giá trị lặp lại dưới dạng đặc biệt trên, với một con trỏ để cách gấp đôi từ vị trí xuất phát, để tìm chu kỳ cho một lần lặp là bội của . Một khi được tìm thấy, thuật toán tìm ngược lại từ lúc ban đầu để tìm giá trị đầu tiên trong chuỗi, khi biết rằng là ước của và do đó . Cuối cùng, một khi đã được biết, bài toán trở nên đơn giản trong việc tìm độ dài cho chu trình lặp lại ngắn nhất, bằng việc tìm vị trí đầu tiên của sao cho .
Thuật toán do đó dùng hai con trỏ, con trỏ đầu tiên (con rùa) nằm tại , và con còn lại (con trỏ) nằm tại . Trong mỗi bước của thuật toán, tăng bởi một, di chuyển con rùa một bước phía trước và con thỏ hai bước phía trước trong chuỗi, rồi so sánh giá trị chuỗi ở hai con trỏ này. Giá trị nhỏ nhất của sao cho rùa và thỏ đều trỏ vào cùng một giá trị là giá trị cần tìm.
Đoạn code Python sau mô tả ý tưởng thuật toán trên:
def floyd(f, x0):
# Main phase of algorithm: finding a repetition x_i = x_2i.
# The hare moves twice as quickly as the tortoise and
# the distance between them increases by 1 at each step.
# Eventually they will both be inside the cycle and then,
# at some point, the distance between them will be
# divisible by the period λ.
tortoise = f(x0) # f(x0) is the element/node next to x0.
hare = f(f(x0))
while tortoise != hare:
tortoise = f(tortoise)
hare = f(f(hare))
# At this point the tortoise position, ν, which is also equal
# to the distance between hare and tortoise, is divisible by
# the period λ. So hare moving in circle one step at a time,
# and tortoise (reset to x0) moving towards the circle, will
# intersect at the beginning of the circle. Because the
# distance between them is constant at 2ν, a multiple of λ,
# they will agree as soon as the tortoise reaches index μ.
# Find the position μ of first repetition.
mu = 0
tortoise = x0
while tortoise != hare:
tortoise = f(tortoise)
hare = f(hare) # Hare and tortoise move at same speed
mu += 1
# Find the length of the shortest cycle starting from x_μ
# The hare moves one step at a time while tortoise is still.
# lam is incremented until λ is found.
lam = 1
hare = f(tortoise)
while tortoise != hare:
hare = f(hare)
lam += 1
return lam, mu
Thuật toán chỉ dùng con trỏ để lưu và sao chép giá trị, tính giá trị hàm và kiểm tra bằng nhau, do đó nó thỏa mãn yêu cầu của thuật toán con trỏ.Thuật toán dùng số phép tính trên, và bộ nhớ.
Thuật toán của Brent
Richard P. Brent mô tả một thuật toán tìm chu trình khác, giống thuật toán rùa và con thỏ, chỉ cần hai con trỏ để duyệt dãy số. Tuy nhiên, nó dựa theo nguyên tắc khác: tìm giá trị lũy thừa bậc hai nhỏ nhất mà lớn hơn cả và . Với , thuật toán so sánh với mỗi giá trị phần tử tiếp theo cho đến khi gặp lũy thừa bậc hai tiếp theo, dừng khi nó gặp một cặp bằng nhau. Thuật toán có hai ưu thế so với thuật toán rùa và con thỏ: nó tìm đúng và trực tiếp giá trị của chu trình, thay vì phải tìm nó trong đoạn mã sau, và các bước của nó chỉ cần một phép tính hơn là 3.
Đoạn code python sau mô tả lại ý tưởng trên.
def brent(f, x0):
# main phase: search successive powers of two
power = lam = 1
tortoise = x0
hare = f(x0) # f(x0) is the element/node next to x0.
while tortoise != hare:
if power == lam: # time to start a new power of two?
tortoise = hare
power *= 2
lam = 0
hare = f(hare)
lam += 1
# Find the position of the first repetition of length λ
tortoise = hare = x0
for i in range(lam):
# range(lam) produces a list with the values 0, 1, ... , lam-1
hare = f(hare)
# The distance between the hare and tortoise is now λ.
# Next, the hare and tortoise move at same speed until they agree
mu = 0
while tortoise != hare:
tortoise = f(tortoise)
hare = f(hare)
mu += 1
return lam, mu
Giống thuật toán rùa và thỏ, đây là thuật toán con trỏ dùng lần kiểm tra và tính hàm cùng với bộ nhớ. Đồng thời cũng không quá khó để chứng minh rằng số lần tính hàm không bao giờ cao hơn số lần tính trong thuật toán của Floyd. Brent cho rằng, trên trung bình, thuật toán tìm chu trình của ông chạy khoảng 36% nhanh hơn so với cái của Floyd và nó đẩy tốc độ cho thuật toán Pollard rho bởi tầm 24%. Ông cũng xét phân tích trung bình cho phiên bản ngẫu nhiên của thuật toán trong đó dãy chỉ số xét bởi con trỏ chậm hơn không phải lũy thừa bậc hai như thường, mà là bội ngẫu nghiên của lũy thừa bậc hai. Mặc dù ông định áp dụng chủ yếu cho các thuật toán phân tích số nguyên, Brent cũng có xét tới các ứng dụng cho việc kiểm nghiệm các bộ sinh số giả ngẫu nhiên.
👁️
0 | 🔗 | 💖 | ✨ | 🌍 | ⌚
Trong Khoa học máy tính, bài toán **phát hiện chu trình** hay **tìm chu trình** là bài tìm thuật toán tìm vòng lặp trong một chuỗi giá trị hàm. Bất kỳ hàm nào ánh
Biểu đồ chu trình carbon. Các số màu đen chỉ ra lượng carbon được lưu giữ trong các nguồn chứa khác nhau, tính bằng tỉ tấn ("GtC" là viết tắt của _GigaTons of Carbon_ (tỉ
ORC với Bộ hồi nhiệt **Chu trình Rankine hữu cơ** (**ORC**) được đặt tên cho việc sử dụng chất lỏng có khối lượng phân tử cao, hữu cơ với sự thay đổi pha hơi-lỏng hoặc
Sơ đồ biểu diễn quá trình luân chuyển nitơ trong môi trường. Trong quá trình này, vi khuẩn đóng vai trò quan trọng, chúng tạo ra các dạng hợp chất nitơ khác nhau có thể
thumb|upright=1.2|Mô hình vật lý của **chu trình Rankine**
1. [[Máy bơm, 2. Lò hơi, 3. Tua bin, 4. Condenser (heat transfer)]] **Chu trình Rankine** là một mô hình được sử dụng để dự đoán hiệu suất
**Chu trình Carnot** là một chu trình nhiệt động lực học thuận nghịch lý tưởng được nghiên cứu bởi Nicolas Léonard Sadi Carnot trong thập niên 1820 và Benoit Paul Émile Clapeyron vào khoảng thập
**PDCA** hay **Chu trình PDCA** (Lập kế hoạch – Thực hiện – Kiểm tra – Cải tiến) là chu trình cải tiến liên tục được Tiến sĩ Deming giới thiệu cho người Nhật trong những
**Chu trình ure** (còn được gọi là **chu trình ornithine**) là một chu trình phản ứng sinh hóa tạo ra ure ((NH2)2CO) từ amonia (NH3). Chu trình này diễn ra ở các các sinh vật
**Chu trình Brayton** là một chu trình nhiệt động lực học, đặt tên theo George Brayton (1830-1892), một kỹ sư người Mỹ, người đã phát triển nó. Năm 1872, Brayton đăng ký bằng sáng chế
nhỏ|[[Mặt Trời, trung tâm của Hệ Mặt Trời (Lưu ý: Mặt Trời là một ngôi sao, không phải hành tinh).]] **Thời gian biểu phát hiện các hành tinh và vệ tinh trong Hệ Mặt
phải|nhỏ|350x350px|Chu trình oxy **Chu trình oxy** là chu trình sinh địa hóa của oxy bên trong bốn nguồn dự trữ chính của nó: khí quyển (không khí), tổng tất cả vật chất sinh học trong
right|thumbnail|Tổng quan về chu trình CNO loại 1 right|thumb|Chu trình Carbon-Nitrogen-Oxygen loại 1 **Chu trình CNO** (cho carbon–nitrogen–oxygen) là một trong hai chuỗi phản ứng nhiệt hạch mà các ngôi sao chuyển hydrogen về helium,
**C** là một ngôn ngữ mệnh lệnh được phát triển từ đầu thập niên 1970 bởi Dennis Ritchie để dùng trong hệ điều hành UNIX. Từ đó, ngôn ngữ này đã lan rộng ra nhiều
thumb|upright|Một mẩu [[giáp cốt có khắc Giáp cốt văn khai quật ở Ân Khư, phát hiện được nhiều phiếu bình chọn nhất.]] Năm 2001, Viện Khảo cổ, Viện Khoa học xã hội Trung Quốc đã
nhỏ|Một góc nhìn lãng mạn về thời khắc đoàn thám hiểm của [[Christopher Columbus đặt chân lên châu Mỹ (Dióscoro Puebla, 1862).]] **Phát hiện ra châu Mỹ** là hội nghị lịch sử được đánh dấu
Ngày 9-1, Khánh Hòa phát động chương trình Người dân Khánh Hòa nói tiếng Anh, nhằm phổ cập tiếng Anh đến toàn dân trên địa bàn tỉnh, hướng tới phục vụ cho du lịch -
**24 Giờ** (, tiếng Anh: Twenty Four Hours) là chương trình thực tế ngoài trời được phát sóng trên kênh vệ tinh Chiết Giang. 6 vị khách nam sẽ là các vị khách thường xuyên
**Phát hiện chuyển động** là quá trình phát hiện sự thay đổi vị trí của vật thể so với môi trường xung quanh hoặc thay đổi môi trường xung quanh một cách tương đối so
Một nhóm nghiên cứu của Trung tâm Công nghệ thông tin và Ngoại ngữ (Công viên Phần mềm Quân đội) - Trường Đại học Thông tin liên lạc vừa nghiên cứu giải pháp kỹ thuật
Trong hai ngày 5-6/9/2024, Đoàn công tác Ủy Ban Mặt trận Tổ quốc Việt Nam TP.HCM, Hội Bảo vệ Thiên nhiên và Môi trường Thành phố cùng đại diện doanh nghiệp đồng hành tham gia
PHÁT HIỆN CON NGƯỜI VÀ CÒI BÁO ĐỘNG Tự động kích hoạt còi báo động để cảnh báo và xua đuổi kẻ lạ mặt khỏi khu vực an ninh của gia đình Imou Ranger 2C
PHÁT HIỆN CON NGƯỜI VÀ CÒI BÁO ĐỘNG Tự động kích hoạt còi báo động để cảnh báo và xua đuổi kẻ lạ mặt khỏi khu vực an ninh của gia đình Imou Ranger 2C
**Phát sinh chủng loại học** (tiếng Anh: _Phylogenetics_ /faɪlɵdʒɪnɛtɪks/, có nguồn gốc từ tiếng Hy Lạp: φυλή, φῦλον - phylé, phylon = chủng loại, bộ tộc, bộ lạc, thị tộc, gia tộc; γενετικός - genetikós
**Pascal** là một ngôn ngữ lập trình cho máy tính thuộc dạng mệnh lệnh và thủ tục, được Niklaus Wirth phát triển vào năm 1970. Pascal là ngôn ngữ lập trình đặc biệt thích hợp
**Chủ nghĩa Marx** hay **Mác-xít** (phiên âm từ Marxist) là hệ thống học thuyết triết học, lịch sử và kinh tế chính trị dựa trên các tác phẩm của Karl Marx (1818 - 1883) và
phải|nhỏ|402x402px|[[Mã nguồn của một chương trình máy tính đơn giản được viết bằng ngôn ngữ lập trình C. Khi được biên dịch và chạy, nó sẽ cho kết quả "Hello, world!".]] **Ngôn ngữ lập trình**
nhỏ|phải|Thai tạng giới [[Mạn-đà-la ()]] nhỏ|phải|Vòng Pháp luân **Nghệ thuật Phật giáo** là sự phản ánh các khái niệm trong đạo Phật dưới các hình thức nghệ thuật khác nhau – nhất là các lĩnh
**Trịnh Công Sơn** (28 tháng 2 năm 1939 – 1 tháng 4 năm 2001) là một nam nhạc sĩ người Việt Nam. Ông được coi là một trong những nhạc sĩ lớn nhất của tân
**Chủ nghĩa tư bản** (Chữ Hán: 主義資本; tiếng Anh: _capitalism_) là một hệ thống kinh tế dựa trên quyền sở hữu tư nhân đối với tư liệu sản xuất và hoạt động sản xuất vì
:_Bài này nói về chủ nghĩa cộng sản như một hình thái xã hội và như một phong trào chính trị. Xin xem bài hệ thống xã hội chủ nghĩa, đảng cộng sản và chủ
nhỏ|Trụ sở Giáo hội Phật giáo Việt Nam tại chùa Quán Sứ, Hà Nội **Giáo hội Phật giáo Việt Nam** là tổ chức Phật giáo toàn quốc của Việt Nam, là đại diện Tăng, Ni,
**Opera** là một trình duyệt web và cũng là một bộ phần mềm Internet được phát triển bởi Opera Software, hiện được hơn 270 triệu người sử dụng trên thế giới. Trình duyệt này bao
nhỏ|phải|Hoa hồng đỏ, biểu trưng của phong trào dân chủ xã hội. **Dân chủ xã hội** là một hệ tư tưởng kinh tế, triết lý chính trị xã hội của chủ nghĩa xã hội ủng
**Vụ phát tán video Senkaku năm 2010** (hoặc ) là một vụ phát tán các video ghi hình vụ va chạm tàu Senkaku năm 2010 trên mạng chia sẻ YouTube do một sĩ quan trưởng
phải|nhỏ|634x634px| Sơ đồ thể hiện tiến trình của chu kỳ kinh nguyệt và các hormone có tác động đến tiến trình này. **Chu kỳ kinh nguyệt** là sự biến đổi tự nhiên thường xuyên xảy
**_2 ngày 1 đêm_** (viết tắt: **_2N1Đ_**) là chương trình truyền hình trải nghiệm thực tế do Đài Truyền hình Thành phố Hồ Chí Minh và công ty Đông Tây Promotion phối hợp thực hiện,
**Phan Châu Trinh** hay **Phan Chu Trinh** (chữ Hán: 潘周楨; 1872 – 1926), hiệu là **Tây Hồ** (西湖), biệt hiệu **Hy Mã** (希瑪), tự là **Tử Cán** (子幹). Ông là nhà thơ, nhà văn, và
**Kinh điển Phật giáo** có số lượng cực kỳ lớn, thậm chí xưa lấy 84.000 để ước chừng tượng trưng về số lượng pháp uẩn. Kinh văn Phật giáo truyền miệng hoặc được viết ở
nhỏ|Tượng minh hoạ [[Đức Phật Chuyển Pháp Luân tại Bảo tàng khảo cổ học Sarnath của Ấn Độ vào thế kỷ 3-5]] **Phật giáo** (tiếng Hán: 佛教 - tiếng Phạn: बुद्ध धर्म - IAST: _Buddha
nhỏ|Bức ảnh này trích trong một chương về [[Ấn Độ trong cuốn _Câu chuyện về các quốc gia của Hutchison_, mô tả Ajatashatru đến thăm Đức Phật để giác ngộ tội lỗi của mình.]] **Phật
nhỏ|Huy Hiệu Hoa Sen**Gia đình Phật tử Việt Nam** (**GĐPTVN**) là một tổ chức giáo dục thanh thiếu niên được thành lập từ những năm 1940, mang danh xưng chính thức là Gia đình Phật
**Khủng hoảng hiến pháp Nga năm 1993** là một cuộc cạnh tranh chính trị giữa phe phái của Tổng thống Nga với nghị viện Nga và phe cánh tả thân Cộng sản, rồi cuối cùng
**_Running Man_** hay **_Running Man Vietnam_** (tên tiếng Việt hiện tại: **_Running Man Vietnam 3 - Chạy ngay đi_**) là phiên bản Việt hóa của chương trình truyền hình thực tế nổi tiếng của Hàn
**Chủ nghĩa tự do hiện đại Hoa Kỳ** là phiên bản chủ đạo của chủ nghĩa tự do tại Hoa Kỳ. Nó kết hợp ý tưởng của tự do dân sự (_civil liberty_) và bình
**Trịnh Xuân Thanh** (sinh ngày 13 tháng 2 năm 1966 tại Hà Nội) từng là Đảng viên Đảng Cộng sản Việt Nam, giữ chức Tỉnh ủy viên (từ năm 2015), Phó Chủ tịch phụ trách
**Sở Nông nghiệp và Phát triển nông thôn** là cơ quan chuyên môn thuộc Uỷ ban nhân dân các tỉnh và thành phố trực thuộc Trung ương (sau đây gọi là Ủy ban nhân dân
Dưới đây là **danh sách chương trình truyền hình đã và đang được phát sóng của Đài Truyền hình Việt Nam**, được chia theo kênh và trạng thái phát sóng. Danh sách này không bao
thế=|nhỏ| [[Tuyên truyền chống cộng của Hoa Kỳ những năm 1950, đặc biệt đề cập đến ngành công nghiệp giải trí ]] **Chủ nghĩa McCarthy** (tiếng Anh: **McCarthyism**) là thuật ngữ nói về việc cáo
Nằm trên phố Hàm Long, thuộc phường Phan Chu Trinh, quận Hoàn Kiếm, Hà Nội, ngôi nhà số 5D thật giản dị với thiết kế một tầng, mái lợp ngói ta. Cách nay 90 năm,
**Chủ tịch nước Cộng hòa xã hội chủ nghĩa Việt Nam** (gọi tắt: **Chủ tịch nước**) là nguyên thủ quốc gia của nước Cộng hòa xã hội chủ nghĩa Việt Nam, là người đứng đầu