MPE Home Metamath Proof Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >  pfxsuff1eqwrdeq Structured version   Visualization version   GIF version

Theorem pfxsuff1eqwrdeq 13897
Description: Two (nonempty) words are equal if and only if they have the same prefix and the same single symbol suffix. (Contributed by Alexander van der Vekens, 23-Sep-2018.) (Revised by AV, 6-May-2020.)
Assertion
Ref Expression
pfxsuff1eqwrdeq ((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) → (𝑊 = 𝑈 ↔ ((♯‘𝑊) = (♯‘𝑈) ∧ ((𝑊 prefix ((♯‘𝑊) − 1)) = (𝑈 prefix ((♯‘𝑊) − 1)) ∧ (lastS‘𝑊) = (lastS‘𝑈)))))

Proof of Theorem pfxsuff1eqwrdeq
StepHypRef Expression
1 hashgt0n0 13576 . . . . . 6 ((𝑊 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) → 𝑊 ≠ ∅)
2 lennncl 13730 . . . . . 6 ((𝑊 ∈ Word 𝑉𝑊 ≠ ∅) → (♯‘𝑊) ∈ ℕ)
31, 2syldan 591 . . . . 5 ((𝑊 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) → (♯‘𝑊) ∈ ℕ)
433adant2 1124 . . . 4 ((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) → (♯‘𝑊) ∈ ℕ)
5 fzo0end 12979 . . . 4 ((♯‘𝑊) ∈ ℕ → ((♯‘𝑊) − 1) ∈ (0..^(♯‘𝑊)))
64, 5syl 17 . . 3 ((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) → ((♯‘𝑊) − 1) ∈ (0..^(♯‘𝑊)))
7 pfxsuffeqwrdeq 13896 . . 3 ((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ ((♯‘𝑊) − 1) ∈ (0..^(♯‘𝑊))) → (𝑊 = 𝑈 ↔ ((♯‘𝑊) = (♯‘𝑈) ∧ ((𝑊 prefix ((♯‘𝑊) − 1)) = (𝑈 prefix ((♯‘𝑊) − 1)) ∧ (𝑊 substr ⟨((♯‘𝑊) − 1), (♯‘𝑊)⟩) = (𝑈 substr ⟨((♯‘𝑊) − 1), (♯‘𝑊)⟩)))))
86, 7syld3an3 1402 . 2 ((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) → (𝑊 = 𝑈 ↔ ((♯‘𝑊) = (♯‘𝑈) ∧ ((𝑊 prefix ((♯‘𝑊) − 1)) = (𝑈 prefix ((♯‘𝑊) − 1)) ∧ (𝑊 substr ⟨((♯‘𝑊) − 1), (♯‘𝑊)⟩) = (𝑈 substr ⟨((♯‘𝑊) − 1), (♯‘𝑊)⟩)))))
9 hashneq0 13575 . . . . . . . . . . 11 (𝑊 ∈ Word 𝑉 → (0 < (♯‘𝑊) ↔ 𝑊 ≠ ∅))
109biimpd 230 . . . . . . . . . 10 (𝑊 ∈ Word 𝑉 → (0 < (♯‘𝑊) → 𝑊 ≠ ∅))
1110imdistani 569 . . . . . . . . 9 ((𝑊 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) → (𝑊 ∈ Word 𝑉𝑊 ≠ ∅))
12113adant2 1124 . . . . . . . 8 ((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) → (𝑊 ∈ Word 𝑉𝑊 ≠ ∅))
1312adantr 481 . . . . . . 7 (((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) ∧ (♯‘𝑊) = (♯‘𝑈)) → (𝑊 ∈ Word 𝑉𝑊 ≠ ∅))
14 swrdlsw 13865 . . . . . . 7 ((𝑊 ∈ Word 𝑉𝑊 ≠ ∅) → (𝑊 substr ⟨((♯‘𝑊) − 1), (♯‘𝑊)⟩) = ⟨“(lastS‘𝑊)”⟩)
1513, 14syl 17 . . . . . 6 (((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) ∧ (♯‘𝑊) = (♯‘𝑈)) → (𝑊 substr ⟨((♯‘𝑊) − 1), (♯‘𝑊)⟩) = ⟨“(lastS‘𝑊)”⟩)
16 breq2 4966 . . . . . . . . . 10 ((♯‘𝑊) = (♯‘𝑈) → (0 < (♯‘𝑊) ↔ 0 < (♯‘𝑈)))
17163anbi3d 1434 . . . . . . . . 9 ((♯‘𝑊) = (♯‘𝑈) → ((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) ↔ (𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑈))))
18 hashneq0 13575 . . . . . . . . . . . . 13 (𝑈 ∈ Word 𝑉 → (0 < (♯‘𝑈) ↔ 𝑈 ≠ ∅))
1918biimpd 230 . . . . . . . . . . . 12 (𝑈 ∈ Word 𝑉 → (0 < (♯‘𝑈) → 𝑈 ≠ ∅))
2019imdistani 569 . . . . . . . . . . 11 ((𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑈)) → (𝑈 ∈ Word 𝑉𝑈 ≠ ∅))
21203adant1 1123 . . . . . . . . . 10 ((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑈)) → (𝑈 ∈ Word 𝑉𝑈 ≠ ∅))
22 swrdlsw 13865 . . . . . . . . . 10 ((𝑈 ∈ Word 𝑉𝑈 ≠ ∅) → (𝑈 substr ⟨((♯‘𝑈) − 1), (♯‘𝑈)⟩) = ⟨“(lastS‘𝑈)”⟩)
2321, 22syl 17 . . . . . . . . 9 ((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑈)) → (𝑈 substr ⟨((♯‘𝑈) − 1), (♯‘𝑈)⟩) = ⟨“(lastS‘𝑈)”⟩)
2417, 23syl6bi 254 . . . . . . . 8 ((♯‘𝑊) = (♯‘𝑈) → ((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) → (𝑈 substr ⟨((♯‘𝑈) − 1), (♯‘𝑈)⟩) = ⟨“(lastS‘𝑈)”⟩))
2524impcom 408 . . . . . . 7 (((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) ∧ (♯‘𝑊) = (♯‘𝑈)) → (𝑈 substr ⟨((♯‘𝑈) − 1), (♯‘𝑈)⟩) = ⟨“(lastS‘𝑈)”⟩)
26 oveq1 7023 . . . . . . . . . . 11 ((♯‘𝑊) = (♯‘𝑈) → ((♯‘𝑊) − 1) = ((♯‘𝑈) − 1))
27 id 22 . . . . . . . . . . 11 ((♯‘𝑊) = (♯‘𝑈) → (♯‘𝑊) = (♯‘𝑈))
2826, 27opeq12d 4718 . . . . . . . . . 10 ((♯‘𝑊) = (♯‘𝑈) → ⟨((♯‘𝑊) − 1), (♯‘𝑊)⟩ = ⟨((♯‘𝑈) − 1), (♯‘𝑈)⟩)
2928oveq2d 7032 . . . . . . . . 9 ((♯‘𝑊) = (♯‘𝑈) → (𝑈 substr ⟨((♯‘𝑊) − 1), (♯‘𝑊)⟩) = (𝑈 substr ⟨((♯‘𝑈) − 1), (♯‘𝑈)⟩))
3029eqeq1d 2797 . . . . . . . 8 ((♯‘𝑊) = (♯‘𝑈) → ((𝑈 substr ⟨((♯‘𝑊) − 1), (♯‘𝑊)⟩) = ⟨“(lastS‘𝑈)”⟩ ↔ (𝑈 substr ⟨((♯‘𝑈) − 1), (♯‘𝑈)⟩) = ⟨“(lastS‘𝑈)”⟩))
3130adantl 482 . . . . . . 7 (((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) ∧ (♯‘𝑊) = (♯‘𝑈)) → ((𝑈 substr ⟨((♯‘𝑊) − 1), (♯‘𝑊)⟩) = ⟨“(lastS‘𝑈)”⟩ ↔ (𝑈 substr ⟨((♯‘𝑈) − 1), (♯‘𝑈)⟩) = ⟨“(lastS‘𝑈)”⟩))
3225, 31mpbird 258 . . . . . 6 (((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) ∧ (♯‘𝑊) = (♯‘𝑈)) → (𝑈 substr ⟨((♯‘𝑊) − 1), (♯‘𝑊)⟩) = ⟨“(lastS‘𝑈)”⟩)
3315, 32eqeq12d 2810 . . . . 5 (((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) ∧ (♯‘𝑊) = (♯‘𝑈)) → ((𝑊 substr ⟨((♯‘𝑊) − 1), (♯‘𝑊)⟩) = (𝑈 substr ⟨((♯‘𝑊) − 1), (♯‘𝑊)⟩) ↔ ⟨“(lastS‘𝑊)”⟩ = ⟨“(lastS‘𝑈)”⟩))
34 fvexd 6553 . . . . . 6 (((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) ∧ (♯‘𝑊) = (♯‘𝑈)) → (lastS‘𝑊) ∈ V)
35 fvex 6551 . . . . . 6 (lastS‘𝑈) ∈ V
36 s111 13813 . . . . . 6 (((lastS‘𝑊) ∈ V ∧ (lastS‘𝑈) ∈ V) → (⟨“(lastS‘𝑊)”⟩ = ⟨“(lastS‘𝑈)”⟩ ↔ (lastS‘𝑊) = (lastS‘𝑈)))
3734, 35, 36sylancl 586 . . . . 5 (((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) ∧ (♯‘𝑊) = (♯‘𝑈)) → (⟨“(lastS‘𝑊)”⟩ = ⟨“(lastS‘𝑈)”⟩ ↔ (lastS‘𝑊) = (lastS‘𝑈)))
3833, 37bitrd 280 . . . 4 (((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) ∧ (♯‘𝑊) = (♯‘𝑈)) → ((𝑊 substr ⟨((♯‘𝑊) − 1), (♯‘𝑊)⟩) = (𝑈 substr ⟨((♯‘𝑊) − 1), (♯‘𝑊)⟩) ↔ (lastS‘𝑊) = (lastS‘𝑈)))
3938anbi2d 628 . . 3 (((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) ∧ (♯‘𝑊) = (♯‘𝑈)) → (((𝑊 prefix ((♯‘𝑊) − 1)) = (𝑈 prefix ((♯‘𝑊) − 1)) ∧ (𝑊 substr ⟨((♯‘𝑊) − 1), (♯‘𝑊)⟩) = (𝑈 substr ⟨((♯‘𝑊) − 1), (♯‘𝑊)⟩)) ↔ ((𝑊 prefix ((♯‘𝑊) − 1)) = (𝑈 prefix ((♯‘𝑊) − 1)) ∧ (lastS‘𝑊) = (lastS‘𝑈))))
4039pm5.32da 579 . 2 ((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) → (((♯‘𝑊) = (♯‘𝑈) ∧ ((𝑊 prefix ((♯‘𝑊) − 1)) = (𝑈 prefix ((♯‘𝑊) − 1)) ∧ (𝑊 substr ⟨((♯‘𝑊) − 1), (♯‘𝑊)⟩) = (𝑈 substr ⟨((♯‘𝑊) − 1), (♯‘𝑊)⟩))) ↔ ((♯‘𝑊) = (♯‘𝑈) ∧ ((𝑊 prefix ((♯‘𝑊) − 1)) = (𝑈 prefix ((♯‘𝑊) − 1)) ∧ (lastS‘𝑊) = (lastS‘𝑈)))))
418, 40bitrd 280 1 ((𝑊 ∈ Word 𝑉𝑈 ∈ Word 𝑉 ∧ 0 < (♯‘𝑊)) → (𝑊 = 𝑈 ↔ ((♯‘𝑊) = (♯‘𝑈) ∧ ((𝑊 prefix ((♯‘𝑊) − 1)) = (𝑈 prefix ((♯‘𝑊) − 1)) ∧ (lastS‘𝑊) = (lastS‘𝑈)))))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 207  wa 396  w3a 1080   = wceq 1522  wcel 2081  wne 2984  Vcvv 3437  c0 4211  cop 4478   class class class wbr 4962  cfv 6225  (class class class)co 7016  0cc0 10383  1c1 10384   < clt 10521  cmin 10717  cn 11486  ..^cfzo 12883  chash 13540  Word cword 13707  lastSclsw 13760  ⟨“cs1 13793   substr csubstr 13838   prefix cpfx 13868
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1777  ax-4 1791  ax-5 1888  ax-6 1947  ax-7 1992  ax-8 2083  ax-9 2091  ax-10 2112  ax-11 2126  ax-12 2141  ax-13 2344  ax-ext 2769  ax-rep 5081  ax-sep 5094  ax-nul 5101  ax-pow 5157  ax-pr 5221  ax-un 7319  ax-cnex 10439  ax-resscn 10440  ax-1cn 10441  ax-icn 10442  ax-addcl 10443  ax-addrcl 10444  ax-mulcl 10445  ax-mulrcl 10446  ax-mulcom 10447  ax-addass 10448  ax-mulass 10449  ax-distr 10450  ax-i2m1 10451  ax-1ne0 10452  ax-1rid 10453  ax-rnegex 10454  ax-rrecex 10455  ax-cnre 10456  ax-pre-lttri 10457  ax-pre-lttrn 10458  ax-pre-ltadd 10459  ax-pre-mulgt0 10460
This theorem depends on definitions:  df-bi 208  df-an 397  df-or 843  df-3or 1081  df-3an 1082  df-tru 1525  df-fal 1535  df-ex 1762  df-nf 1766  df-sb 2043  df-mo 2576  df-eu 2612  df-clab 2776  df-cleq 2788  df-clel 2863  df-nfc 2935  df-ne 2985  df-nel 3091  df-ral 3110  df-rex 3111  df-reu 3112  df-rab 3114  df-v 3439  df-sbc 3707  df-csb 3812  df-dif 3862  df-un 3864  df-in 3866  df-ss 3874  df-pss 3876  df-nul 4212  df-if 4382  df-pw 4455  df-sn 4473  df-pr 4475  df-tp 4477  df-op 4479  df-uni 4746  df-int 4783  df-iun 4827  df-br 4963  df-opab 5025  df-mpt 5042  df-tr 5064  df-id 5348  df-eprel 5353  df-po 5362  df-so 5363  df-fr 5402  df-we 5404  df-xp 5449  df-rel 5450  df-cnv 5451  df-co 5452  df-dm 5453  df-rn 5454  df-res 5455  df-ima 5456  df-pred 6023  df-ord 6069  df-on 6070  df-lim 6071  df-suc 6072  df-iota 6189  df-fun 6227  df-fn 6228  df-f 6229  df-f1 6230  df-fo 6231  df-f1o 6232  df-fv 6233  df-riota 6977  df-ov 7019  df-oprab 7020  df-mpo 7021  df-om 7437  df-1st 7545  df-2nd 7546  df-wrecs 7798  df-recs 7860  df-rdg 7898  df-1o 7953  df-oadd 7957  df-er 8139  df-en 8358  df-dom 8359  df-sdom 8360  df-fin 8361  df-card 9214  df-pnf 10523  df-mnf 10524  df-xr 10525  df-ltxr 10526  df-le 10527  df-sub 10719  df-neg 10720  df-nn 11487  df-n0 11746  df-xnn0 11816  df-z 11830  df-uz 12094  df-fz 12743  df-fzo 12884  df-hash 13541  df-word 13708  df-lsw 13761  df-s1 13794  df-substr 13839  df-pfx 13869
This theorem is referenced by:  wwlksnextinj  27364  clwwlkf1  27515
  Copyright terms: Public domain W3C validator