溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

oracle kmp

發(fā)布時間:2020-07-06 00:34:21 來源:網(wǎng)絡(luò) 閱讀:256 作者:小??炫躧e 欄目:關(guān)系型數(shù)據(jù)庫

CREATE OR REPLACE PACKAGE KMP_ALGOR_PKG

AS

  TYPE next_arr_tt IS TABLE OF INT INDEX BY PLS_INTEGER;

  PROCEDURE match_str(org_str VARCHAR2, pat_str VARCHAR2);

  FUNCTION  get_pre_arr(pat_st VARCHAR2) RETURN next_arr_tt;

END kmp_algor_pkg;


CREATE OR REPLACE PACKAGE BODY KMP_ALGOR_PKG

AS

  PROCEDURE match_str(org_str VARCHAR2, pat_str VARCHAR2)

  AS

      pat_next_arr next_arr_tt := get_pre_arr(pat_st => pat_str);

      k INT := 0;

      seq_cnt INT := 0;

  BEGIN

      FOR i IN 1..length(org_str) LOOP

         WHILE(k > 0 AND substr(org_str, i, 1) <> substr(pat_str, k + 1, 1)) LOOP

            k := pat_next_arr(k-1);

         END LOOP;

         

         IF(substr(pat_str, k + 1, 1) = substr(org_str, i, 1)) THEN

            k := k + 1;

         END IF;

         

         IF(k = length(pat_str)) THEN

            seq_cnt := seq_cnt + 1;

            dbms_output.put_line('the '||pat_str||'  '||seq_cnt||'th match found in '||org_str||' at index '||(i - k + 1));

            k := pat_next_arr(k - 1);

         END IF;

      END LOOP;

      

      IF(seq_cnt = 0) THEN

         dbms_output.put_line('no match found');

      END IF;

  END match_str;


  FUNCTION  get_pre_arr(pat_st VARCHAR2) RETURN next_arr_tt

  AS

     ret_next_arr next_arr_tt;

     k INT := 0;

  BEGIN

     ret_next_arr(0) := 0;

     FOR umark IN 1..length(pat_st) - 1 LOOP

        WHILE(k > 0 AND substr(pat_st, umark + 1 , 1) <> substr(pat_st, k + 1, 1)) LOOP

             k := ret_next_arr(k - 1);

        END LOOP;

        IF(substr(pat_st, k + 1, 1) = substr(pat_st, umark + 1, 1)) THEN

            k := k + 1;

        END IF;

        ret_next_arr(umark) := k;

     END LOOP;

     RETURN ret_next_arr;

  END get_pre_arr;

END kmp_algor_pkg;


向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI