الفرق بين المراجعتين لصفحة: «Algorithms/String Searching Algorithms»

من موسوعة حسوب
طلا ملخص تعديل
لا ملخص تعديل
 
(مراجعة متوسطة واحدة بواسطة مستخدم واحد آخر غير معروضة)
سطر 17: سطر 17:


تعتمد خوارزمية بوير-مور Boyer-Moore على الأسلوبين: استكشاف الحروف السيئة، واستكشاف اللاحقة الجيدة.
تعتمد خوارزمية بوير-مور Boyer-Moore على الأسلوبين: استكشاف الحروف السيئة، واستكشاف اللاحقة الجيدة.
== [[Algorithms/Aho Corasick|خوارزمية آهو-كوراسك]] ==


== [[Algorithms/Z|خوارزمية Z]] ==
== [[Algorithms/Z|خوارزمية Z]] ==


تستعين الخوارزمية بمصفوفة <code>Z</code> في البحث عن النمط المعطى، ويخزّن العنصر <code>Z[i]</code>‎ طول أطول سلسلة نصية فرعية تبدأ من الموقع <code>str[i]</code>‎ والتي تكون في الوقت نفسه سابقة للسلسة النصية <code>str[0..n-1]</code>‎.
تستعين الخوارزمية بمصفوفة <code>Z</code> في البحث عن النمط المعطى، ويخزّن العنصر <code>Z[i]</code>‎ طول أطول سلسلة نصية فرعية تبدأ من الموقع <code>str[i]</code>‎ والتي تكون في الوقت نفسه سابقة للسلسة النصية <code>str[0..n-1]</code>‎.
{{NUMBEROFARTICLES}}


[[تصنيف: الخوارزميات]]
[[تصنيف: الخوارزميات]]

المراجعة الحالية بتاريخ 19:47، 20 أكتوبر 2019

تعدّ خوارزميات البحث عن النصوص (وتسمّى كذلك بخوارزميات البحث عن الأنماط Pattern Searching) جزءًا من خوارزميات النصوص String Algorithms، وتساعد هذه الخوارزميات في البحث عن سلسلة نصية معيّنة في سلسلة نصية أخرى.

الخوارزمية البسيطة

تنتقل الخوارزمية عبر جميع الحروف في السلسلة النصية واحدًا تلو الآخر بحثًا عن التسلسل الذي يطابق النمط المعطى.

خوارزمية KMP

تعالج الخوارزمية النمط المراد البحث عنه لتجنّب تكرار البحث عن أنماط جرى البحث عنها في الخطوات السابقة.

خوارزمية رابين-كارب

تحرّك خوارزمية رابين-كارب Rabin-Karp النمط الذي تبحث عنه عبر السلسلة النصية موقعًا تلو الآخر وتطابق قيمة التقطيع Hash value للنمط المعطى مع قيمة التقطيع لجزء السلسلة الذي تجري معه المقارنة

خوارزمية بوير-مور

تعتمد خوارزمية بوير-مور Boyer-Moore على الأسلوبين: استكشاف الحروف السيئة، واستكشاف اللاحقة الجيدة.

خوارزمية Z

تستعين الخوارزمية بمصفوفة Z في البحث عن النمط المعطى، ويخزّن العنصر Z[i]‎ طول أطول سلسلة نصية فرعية تبدأ من الموقع str[i]‎ والتي تكون في الوقت نفسه سابقة للسلسة النصية str[0..n-1]‎.