Sign in
or
Register
Courses
Textbook
Compiler
Contests
Topics
Computer Science. Textbook
سلاسل
بور
شريط h6>
Bor هو بنية بيانات لتخزين مجموعة من السلاسل ، وهي شجرة متجذرة برموز على الحواف. & nbsp؛ < / div>
يتوافق كل رأس بورون مع بادئة من سلسلة مضافة. يتم الحصول على هذه البادئة نفسها عن طريق كتابة الأحرف بالتسلسل على الحواف على المسار من الجذر إلى هذا الرأس. في نفس الوقت ، رأس واحد بالضبط يتوافق مع كل بادئة موجودة. & nbsp ؛ جذر بور يتوافق مع سلسلة فارغة.
مثال البورون لـ {be، bee، can، cat، cd}
يشير البرتقالي إلى الرؤوس التي تتوافق مع الكلمات من المجموعة نفسها. يطلق عليهم
محطات tt>
.
يوجد أدناه رمز تخزين البورون وإضافة خطوط إليه. هذه الطريقة تخزن التجويف من خلال مصفوفة. هناك أيضًا تنفيذ من خلال المؤشرات ، والذي يتم تقديمه في رمز مهمة التدريب.
نبسب ؛
// حجم الأبجدية في الكلمات المدروسة const int alpha = 26 ؛ // هيكل الجزء العلوي من الحفر عقدة البنية { // متجه الحواف في شكل جدول مجاور ، أي: // التالي [0] - الطفل عند القفز فوق الحرف رقم 0 (& # 39 ؛ a & # 39 ؛) // التالي [1] - الطفل عند القفز فوق الحرف رقم 1 (& # 39 ؛ b & # 39 ؛) // إلخ. ناقلات
التالي ؛ // خيارات اضافية // في هذه الحالة ، ارتفاع الرأس h وعلم النهايات ح ح مصطلح منطقي ؛؛ العقدة (ح ح) { next.resize (alph، -1) ؛ // في البداية بدون حواف هذا- & GT ؛ ح = ح ؛ // الارتفاع يساوي المحدد المصطلح = خطأ ؛ // أعلى ليس محطة بشكل افتراضي } } ؛ // قائمة الرؤوس ، الجذر مبدئيًا عند ارتفاع صفر متجه <عقدة> ثلاثي (1 ، عقدة (0)) ؛ // وظيفة لإضافة سلسلة إلى البورون إضافة باطلة (سلسلة ثابتة & أمبير ؛ ق) { كثافة العمليات = 0 ؛ // رقم الرأس الحالي ، بدءًا من الجذر forn (i، (int) s.size ()) { int c = s [i] - & # 39 ؛ a & # 39 ؛؛ // احصل على رقم الحرف الحالي في السلسلة // إذا لم يكن الانتقال المطلوب موجودًا بعد ، فسنقوم بعمل انتقال جديد إذا (trie [v] .next [c] == -1) { trie [v] .next [c] = (int) trie.size () ؛ // رقم الرأس الجديد هو نبسب ؛ // حجم الحفر الحالي (مع 0 ترقيم) trie.push_back (عقدة (trie [v] .h + 1)) ؛ // أنشئ قمة جديدة بارتفاع 1 أكثر } v = trie [v] .next [c] ؛ // تحرك على طول الحافة المرغوبة } // عندما وصلنا إلى القمة ، نبسب ؛ // الذي يطابق السلسلة بأكملها ، نبسب ؛ // ثم ضع علامة عليها كمحطة طرفية trie [v] .term = صحيح ؛ }
إذا كنت بحاجة إلى دعم حذف الصفوف من البورون ، فمن المحتمل أن يتضح أنه غير أمين. أي ببساطة قم بإزالة العلم الطرفي (أو ، ربما ، بدلاً من العلم ، ستحتاج إلى تخزين رقم متغير) ، وترك شجرة البورون نفسها دون تغيير.
وبالتالي ، فإن الإدراج / البحث / الحذف غير العادل يعمل في الوقت الخطي من طول سلسلة الاستعلام.
سيشغل البورون نفسه ، في أسوأ الأحوال ، ذاكرة
O (n | & Sigma؛ |)
، حيث يمثل
n
الطول الإجمالي لجميع السلاسل ، و
& Sigma؛
> - أبجدية السلاسل المستخدمة.
لحل هذه المشكلة ، ستساعدك نظرية تحليل اللعبة بشكل كبير على: & nbsp ؛ https: //e-maxx.ru/algo/games_on_graphs