diff options
| author | akiyamn | 2021-03-25 15:43:19 +1100 | 
|---|---|---|
| committer | akiyamn | 2021-03-25 15:43:19 +1100 | 
| commit | 2b8825876282a741cd665975b367f0e7c71c38a9 (patch) | |
| tree | 4a3c3cf0eae6492e27abdd4a5f78c90ce91fab54 | |
| parent | eebe71f99993fee680df317f36a3948f954c8e49 (diff) | |
| download | fit3155-2b8825876282a741cd665975b367f0e7c71c38a9.tar.gz fit3155-2b8825876282a741cd665975b367f0e7c71c38a9.zip | |
BM: goodbye bad char shift
| -rw-r--r-- | ass1/binary_boyermoore.py | 26 | 
1 files changed, 14 insertions, 12 deletions
| diff --git a/ass1/binary_boyermoore.py b/ass1/binary_boyermoore.py index aa5d0c5..a4d286d 100644 --- a/ass1/binary_boyermoore.py +++ b/ass1/binary_boyermoore.py @@ -127,7 +127,7 @@ def boyer_moore(pat, txt):                      break              else:                  mismatched = txt[j+i] -                bad_char_shift = i-R[alpha_number(mismatched)][i] +                # bad_char_shift = i-R[alpha_number(mismatched)][i]                  good_suffix_shift = 1                  if good_suffix[i+1] > 0: @@ -143,22 +143,24 @@ def boyer_moore(pat, txt):                  elif matches == m:                      print(f"Match at {j}")                      good_suffix_shift = m - matched_prefix[1] +                # assert good_suffix[i+1] != 0                  # print(start, stop) -                j += max(good_suffix_shift, bad_char_shift) +                j += good_suffix_shift                  # print(good_suffix_shift, bad_char_shift) -                if good_suffix_shift >= bad_char_shift: -                    print("good suff", good_suffix_shift) -                else: -                    print("bad char", bad_char_shift) -                    print(i) -                if good_suffix[i+1] >= 0 and good_suffix_shift >= bad_char_shift: -                    galil_index = j +                # if good_suffix_shift >= bad_char_shift: +                #     print("good suff", good_suffix_shift) +                # else: +                #     print("bad char", bad_char_shift) +                #     print(i) +                # if good_suffix[i+1] >= 0 and good_suffix_shift >= bad_char_shift: +                #     galil_index = j                  break      print(f"It found {occurrence} occurences.")      print(f"\n  {list(range(m))}") -    for i, a in enumerate(R): -        print(chr(i+97), a) +    # for i, a in enumerate(R): +    #     print(chr(i+97), a) +    print(good_suffix)      print(f"{comps} comparisons.") -boyer_moore("111101111111111", "101010111010010101110111010101110100101011101101111011111111111101110111010101110100101011101101101110111010101110100101011101101101110110000110101011101001010111011011011101100001010101110100101011101110101011101001010111011011011101110101011101001010111011011011101110101011101001010111011011011101100001101010111010010101110110110111011000010111011111011101110110101110110101101100000001011001010101010101110111110111011101101011101101011011000000010110010101010101000010111011111011101110110101110110101101100000001011001010101010100001011101111101110111011010111011010110110000000101100101010101010101011101001010111011011011101100001011101111101110111011010101110100101011101101101110110000101110111110101010111010010101110110110111011000010111011101010111010010101110110110111011000010111010101110100101011101101101010101110100101011101101101110110000101110111110111011101101011101101011011000000010110010101010101111011000010111011111011101110110101110110101101100000001011001010101010110111110111011101101011101101011011000000010110010101010101111011101110110101110110101101100000001011001010101010111101110110101110110101101100000001011001010101010110101110110101101100000001011001010101010110110111011000010101011101001010111011101010111010010101110110110111011101010111010010101110110110111011101010111010010101110110110111011000011010101110100101011101101101110110000101110111110111011101101011101101011011000000010110010101010101011101111101110111011010111011010110110000000101100101010101010000101110111110111011101101011101101011011000000010110010101010101000010111011111011101110110101110110101101100000001011001010101010101010111010010101110110110111011000010111011111011101110110101011101001010111011011011101100001011101111101010101110100101011101101101110110000101110111010101110100101011101101101110110000101110101011101001010111011011010101011101001010111011011011101100001011101111101110111011010111011010110110000000101100101010101011110110000101110111110111011101101011101101011011000000010110010101010101101111101110111011010111011010110110000000101100101010101011110111011101101011101101011011000000010110010101010101111011101101011101101011011000000010110010101010101101011101101011011000000010110010101010101101101110110000101110111110111011101101011101101011011000000010110010101010101101110111110111011101101011101101011011000000010110010101010101101110111110111011101101011101101011011000000010110010101010101011101111101110111011010111011010110110000000101100101010101010000101110111110111011101101011101101011011000000010110010101010101000010111011111011101110110101110110101101100000001011001010101010101010111101111111111111010010101110110110111011000010111011111011101110110101011101001010111011011011101100001011101111101010101110100101011101101101110110000101110111010101110100101011101101101110110000101110101011101001010111011011010101011101001010111011011011101100001011101111101110111011010111011010110110000000101100101010101011110110000101110111110111011101101011101101011011000000010110010101010101101111101110111011010111011010110110000000101100101010101011110111011101101011101101011011000000010110010101010101111011101101011101101011011000000010110010101010101101011101101011011000000010110010101010101101101110110000101110111110111011101101011101101011011000000010110010101010101")
\ No newline at end of file +boyer_moore("010010", "101010111010010101110111010101110100101011101101111011111111111101110111010101110100101011101101101110111010101110100101011101101101110110000110101011101001010111011011011101100001010101110100101011101110101011101001010111011011011101110101011101001010111011011011101110101011101001010111011011011101100001101010111010010101110110110111011000010111011111011101110110101110110101101100000001011001010101010101110111110111011101101011101101011011000000010110010101010101000010111011111011101110110101110110101101100000001011001010101010100001011101111101110111011010111011010110110000000101100101010101010101011101001010111011011011101100001011101111101110111011010101110100101011101101101110110000101110111110101010111010010101110110110111011000010111011101010111010010101110110110111011000010111010101110100101011101101101010101110100101011101101101110110000101110111110111011101101011101101011011000000010110010101010101111011000010111011111011101110110101110110101101100000001011001010101010110111110111011101101011101101011011000000010110010101010101111011101110110101110110101101100000001011001010101010111101110110101110110101101100000001011001010101010110101110110101101100000001011001010101010110110111011000010101011101001010111011101010111010010101110110110111011101010111010010101110110110111011101010111010010101110110110111011000011010101110100101011101101101110110000101110111110111011101101011101101011011000000010110010101010101011101111101110111011010111011010110110000000101100101010101010000101110111110111011101101011101101011011000000010110010101010101000010111011111011101110110101110110101101100000001011001010101010101010111010010101110110110111011000010111011111011101110110101011101001010111011011011101100001011101111101010101110100101011101101101110110000101110111010101110100101011101101101110110000101110101011101001010111011011010101011101001010111011011011101100001011101111101110111011010111011010110110000000101100101010101011110110000101110111110111011101101011101101011011000000010110010101010101101111101110111011010111011010110110000000101100101010101011110111011101101011101101011011000000010110010101010101111011101101011101101011011000000010110010101010101101011101101011011000000010110010101010101101101110110000101110111110111011101101011101101011011000000010110010101010101101110111110111011101101011101101011011000000010110010101010101101110111110111011101101011101101011011000000010110010101010101011101111101110111011010111011010110110000000101100101010101010000101110111110111011101101011101101011011000000010110010101010101000010111011111011101110110101110110101101100000001011001010101010101010111101111111111111010010101110110110111011000010111011111011101110110101011101001010111011011011101100001011101111101010101110100101011101101101110110000101110111010101110100101011101101101110110000101110101011101001010111011011010101011101001010111011011011101100001011101111101110111011010111011010110110000000101100101010101011110110000101110111110111011101101011101101011011000000010110010101010101101111101110111011010111011010110110000000101100101010101011110111011101101011101101011011000000010110010101010101111011101101011101101011011000000010110010101010101101011101101011011000000010110010101010101101101110110000101110111110111011101101011101101011011000000010110010101010101")
\ No newline at end of file | 
