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

Theorem 3dvds 15855
Description: A rule for divisibility by 3 of a number written in base 10. This is Metamath 100 proof #85. (Contributed by Mario Carneiro, 14-Jul-2014.) (Revised by Mario Carneiro, 17-Jan-2015.) (Revised by AV, 8-Sep-2021.)
Assertion
Ref Expression
3dvds ((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) → (3 ∥ Σ𝑘 ∈ (0...𝑁)((𝐹𝑘) · (10↑𝑘)) ↔ 3 ∥ Σ𝑘 ∈ (0...𝑁)(𝐹𝑘)))
Distinct variable groups:   𝑘,𝐹   𝑘,𝑁

Proof of Theorem 3dvds
Dummy variable 𝑗 is distinct from all other variables.
StepHypRef Expression
1 3z 12175 . . 3 3 ∈ ℤ
21a1i 11 . 2 ((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) → 3 ∈ ℤ)
3 fzfid 13511 . . 3 ((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) → (0...𝑁) ∈ Fin)
4 ffvelrn 6880 . . . . 5 ((𝐹:(0...𝑁)⟶ℤ ∧ 𝑘 ∈ (0...𝑁)) → (𝐹𝑘) ∈ ℤ)
54adantll 714 . . . 4 (((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) ∧ 𝑘 ∈ (0...𝑁)) → (𝐹𝑘) ∈ ℤ)
6 10nn 12274 . . . . . 6 10 ∈ ℕ
76nnzi 12166 . . . . 5 10 ∈ ℤ
8 elfznn0 13170 . . . . . 6 (𝑘 ∈ (0...𝑁) → 𝑘 ∈ ℕ0)
98adantl 485 . . . . 5 (((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) ∧ 𝑘 ∈ (0...𝑁)) → 𝑘 ∈ ℕ0)
10 zexpcl 13615 . . . . 5 ((10 ∈ ℤ ∧ 𝑘 ∈ ℕ0) → (10↑𝑘) ∈ ℤ)
117, 9, 10sylancr 590 . . . 4 (((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) ∧ 𝑘 ∈ (0...𝑁)) → (10↑𝑘) ∈ ℤ)
125, 11zmulcld 12253 . . 3 (((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) ∧ 𝑘 ∈ (0...𝑁)) → ((𝐹𝑘) · (10↑𝑘)) ∈ ℤ)
133, 12fsumzcl 15264 . 2 ((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) → Σ𝑘 ∈ (0...𝑁)((𝐹𝑘) · (10↑𝑘)) ∈ ℤ)
143, 5fsumzcl 15264 . 2 ((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) → Σ𝑘 ∈ (0...𝑁)(𝐹𝑘) ∈ ℤ)
1512, 5zsubcld 12252 . . . 4 (((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) ∧ 𝑘 ∈ (0...𝑁)) → (((𝐹𝑘) · (10↑𝑘)) − (𝐹𝑘)) ∈ ℤ)
16 ax-1cn 10752 . . . . . . . . . . . 12 1 ∈ ℂ
176nncni 11805 . . . . . . . . . . . 12 10 ∈ ℂ
1816, 17negsubdi2i 11129 . . . . . . . . . . 11 -(1 − 10) = (10 − 1)
19 9p1e10 12260 . . . . . . . . . . . . 13 (9 + 1) = 10
2019eqcomi 2745 . . . . . . . . . . . 12 10 = (9 + 1)
2120oveq1i 7201 . . . . . . . . . . 11 (10 − 1) = ((9 + 1) − 1)
22 9cn 11895 . . . . . . . . . . . 12 9 ∈ ℂ
2322, 16pncan3oi 11059 . . . . . . . . . . 11 ((9 + 1) − 1) = 9
2418, 21, 233eqtri 2763 . . . . . . . . . 10 -(1 − 10) = 9
25 3t3e9 11962 . . . . . . . . . 10 (3 · 3) = 9
2624, 25eqtr4i 2762 . . . . . . . . 9 -(1 − 10) = (3 · 3)
2717a1i 11 . . . . . . . . . . . . . . 15 (𝑘 ∈ ℕ010 ∈ ℂ)
28 1re 10798 . . . . . . . . . . . . . . . . 17 1 ∈ ℝ
29 1lt10 12397 . . . . . . . . . . . . . . . . 17 1 < 10
3028, 29gtneii 10909 . . . . . . . . . . . . . . . 16 10 ≠ 1
3130a1i 11 . . . . . . . . . . . . . . 15 (𝑘 ∈ ℕ010 ≠ 1)
32 id 22 . . . . . . . . . . . . . . 15 (𝑘 ∈ ℕ0𝑘 ∈ ℕ0)
3327, 31, 32geoser 15394 . . . . . . . . . . . . . 14 (𝑘 ∈ ℕ0 → Σ𝑗 ∈ (0...(𝑘 − 1))(10↑𝑗) = ((1 − (10↑𝑘)) / (1 − 10)))
34 fzfid 13511 . . . . . . . . . . . . . . 15 (𝑘 ∈ ℕ0 → (0...(𝑘 − 1)) ∈ Fin)
35 elfznn0 13170 . . . . . . . . . . . . . . . . 17 (𝑗 ∈ (0...(𝑘 − 1)) → 𝑗 ∈ ℕ0)
3635adantl 485 . . . . . . . . . . . . . . . 16 ((𝑘 ∈ ℕ0𝑗 ∈ (0...(𝑘 − 1))) → 𝑗 ∈ ℕ0)
37 zexpcl 13615 . . . . . . . . . . . . . . . 16 ((10 ∈ ℤ ∧ 𝑗 ∈ ℕ0) → (10↑𝑗) ∈ ℤ)
387, 36, 37sylancr 590 . . . . . . . . . . . . . . 15 ((𝑘 ∈ ℕ0𝑗 ∈ (0...(𝑘 − 1))) → (10↑𝑗) ∈ ℤ)
3934, 38fsumzcl 15264 . . . . . . . . . . . . . 14 (𝑘 ∈ ℕ0 → Σ𝑗 ∈ (0...(𝑘 − 1))(10↑𝑗) ∈ ℤ)
4033, 39eqeltrrd 2832 . . . . . . . . . . . . 13 (𝑘 ∈ ℕ0 → ((1 − (10↑𝑘)) / (1 − 10)) ∈ ℤ)
41 1z 12172 . . . . . . . . . . . . . . 15 1 ∈ ℤ
42 zsubcl 12184 . . . . . . . . . . . . . . 15 ((1 ∈ ℤ ∧ 10 ∈ ℤ) → (1 − 10) ∈ ℤ)
4341, 7, 42mp2an 692 . . . . . . . . . . . . . 14 (1 − 10) ∈ ℤ
4428, 29ltneii 10910 . . . . . . . . . . . . . . 15 1 ≠ 10
4516, 17subeq0i 11123 . . . . . . . . . . . . . . . 16 ((1 − 10) = 0 ↔ 1 = 10)
4645necon3bii 2984 . . . . . . . . . . . . . . 15 ((1 − 10) ≠ 0 ↔ 1 ≠ 10)
4744, 46mpbir 234 . . . . . . . . . . . . . 14 (1 − 10) ≠ 0
487, 32, 10sylancr 590 . . . . . . . . . . . . . . 15 (𝑘 ∈ ℕ0 → (10↑𝑘) ∈ ℤ)
49 zsubcl 12184 . . . . . . . . . . . . . . 15 ((1 ∈ ℤ ∧ (10↑𝑘) ∈ ℤ) → (1 − (10↑𝑘)) ∈ ℤ)
5041, 48, 49sylancr 590 . . . . . . . . . . . . . 14 (𝑘 ∈ ℕ0 → (1 − (10↑𝑘)) ∈ ℤ)
51 dvdsval2 15781 . . . . . . . . . . . . . 14 (((1 − 10) ∈ ℤ ∧ (1 − 10) ≠ 0 ∧ (1 − (10↑𝑘)) ∈ ℤ) → ((1 − 10) ∥ (1 − (10↑𝑘)) ↔ ((1 − (10↑𝑘)) / (1 − 10)) ∈ ℤ))
5243, 47, 50, 51mp3an12i 1467 . . . . . . . . . . . . 13 (𝑘 ∈ ℕ0 → ((1 − 10) ∥ (1 − (10↑𝑘)) ↔ ((1 − (10↑𝑘)) / (1 − 10)) ∈ ℤ))
5340, 52mpbird 260 . . . . . . . . . . . 12 (𝑘 ∈ ℕ0 → (1 − 10) ∥ (1 − (10↑𝑘)))
5448zcnd 12248 . . . . . . . . . . . . 13 (𝑘 ∈ ℕ0 → (10↑𝑘) ∈ ℂ)
55 negsubdi2 11102 . . . . . . . . . . . . 13 (((10↑𝑘) ∈ ℂ ∧ 1 ∈ ℂ) → -((10↑𝑘) − 1) = (1 − (10↑𝑘)))
5654, 16, 55sylancl 589 . . . . . . . . . . . 12 (𝑘 ∈ ℕ0 → -((10↑𝑘) − 1) = (1 − (10↑𝑘)))
5753, 56breqtrrd 5067 . . . . . . . . . . 11 (𝑘 ∈ ℕ0 → (1 − 10) ∥ -((10↑𝑘) − 1))
58 peano2zm 12185 . . . . . . . . . . . . 13 ((10↑𝑘) ∈ ℤ → ((10↑𝑘) − 1) ∈ ℤ)
5948, 58syl 17 . . . . . . . . . . . 12 (𝑘 ∈ ℕ0 → ((10↑𝑘) − 1) ∈ ℤ)
60 dvdsnegb 15798 . . . . . . . . . . . 12 (((1 − 10) ∈ ℤ ∧ ((10↑𝑘) − 1) ∈ ℤ) → ((1 − 10) ∥ ((10↑𝑘) − 1) ↔ (1 − 10) ∥ -((10↑𝑘) − 1)))
6143, 59, 60sylancr 590 . . . . . . . . . . 11 (𝑘 ∈ ℕ0 → ((1 − 10) ∥ ((10↑𝑘) − 1) ↔ (1 − 10) ∥ -((10↑𝑘) − 1)))
6257, 61mpbird 260 . . . . . . . . . 10 (𝑘 ∈ ℕ0 → (1 − 10) ∥ ((10↑𝑘) − 1))
63 negdvdsb 15797 . . . . . . . . . . 11 (((1 − 10) ∈ ℤ ∧ ((10↑𝑘) − 1) ∈ ℤ) → ((1 − 10) ∥ ((10↑𝑘) − 1) ↔ -(1 − 10) ∥ ((10↑𝑘) − 1)))
6443, 59, 63sylancr 590 . . . . . . . . . 10 (𝑘 ∈ ℕ0 → ((1 − 10) ∥ ((10↑𝑘) − 1) ↔ -(1 − 10) ∥ ((10↑𝑘) − 1)))
6562, 64mpbid 235 . . . . . . . . 9 (𝑘 ∈ ℕ0 → -(1 − 10) ∥ ((10↑𝑘) − 1))
6626, 65eqbrtrrid 5075 . . . . . . . 8 (𝑘 ∈ ℕ0 → (3 · 3) ∥ ((10↑𝑘) − 1))
67 muldvds1 15805 . . . . . . . . 9 ((3 ∈ ℤ ∧ 3 ∈ ℤ ∧ ((10↑𝑘) − 1) ∈ ℤ) → ((3 · 3) ∥ ((10↑𝑘) − 1) → 3 ∥ ((10↑𝑘) − 1)))
681, 1, 59, 67mp3an12i 1467 . . . . . . . 8 (𝑘 ∈ ℕ0 → ((3 · 3) ∥ ((10↑𝑘) − 1) → 3 ∥ ((10↑𝑘) − 1)))
6966, 68mpd 15 . . . . . . 7 (𝑘 ∈ ℕ0 → 3 ∥ ((10↑𝑘) − 1))
709, 69syl 17 . . . . . 6 (((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) ∧ 𝑘 ∈ (0...𝑁)) → 3 ∥ ((10↑𝑘) − 1))
7111, 58syl 17 . . . . . . 7 (((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) ∧ 𝑘 ∈ (0...𝑁)) → ((10↑𝑘) − 1) ∈ ℤ)
72 dvdsmultr2 15822 . . . . . . 7 ((3 ∈ ℤ ∧ (𝐹𝑘) ∈ ℤ ∧ ((10↑𝑘) − 1) ∈ ℤ) → (3 ∥ ((10↑𝑘) − 1) → 3 ∥ ((𝐹𝑘) · ((10↑𝑘) − 1))))
731, 5, 71, 72mp3an2i 1468 . . . . . 6 (((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) ∧ 𝑘 ∈ (0...𝑁)) → (3 ∥ ((10↑𝑘) − 1) → 3 ∥ ((𝐹𝑘) · ((10↑𝑘) − 1))))
7470, 73mpd 15 . . . . 5 (((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) ∧ 𝑘 ∈ (0...𝑁)) → 3 ∥ ((𝐹𝑘) · ((10↑𝑘) − 1)))
755zcnd 12248 . . . . . 6 (((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) ∧ 𝑘 ∈ (0...𝑁)) → (𝐹𝑘) ∈ ℂ)
7611zcnd 12248 . . . . . 6 (((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) ∧ 𝑘 ∈ (0...𝑁)) → (10↑𝑘) ∈ ℂ)
7775, 76muls1d 11257 . . . . 5 (((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) ∧ 𝑘 ∈ (0...𝑁)) → ((𝐹𝑘) · ((10↑𝑘) − 1)) = (((𝐹𝑘) · (10↑𝑘)) − (𝐹𝑘)))
7874, 77breqtrd 5065 . . . 4 (((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) ∧ 𝑘 ∈ (0...𝑁)) → 3 ∥ (((𝐹𝑘) · (10↑𝑘)) − (𝐹𝑘)))
793, 2, 15, 78fsumdvds 15832 . . 3 ((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) → 3 ∥ Σ𝑘 ∈ (0...𝑁)(((𝐹𝑘) · (10↑𝑘)) − (𝐹𝑘)))
8012zcnd 12248 . . . 4 (((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) ∧ 𝑘 ∈ (0...𝑁)) → ((𝐹𝑘) · (10↑𝑘)) ∈ ℂ)
813, 80, 75fsumsub 15315 . . 3 ((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) → Σ𝑘 ∈ (0...𝑁)(((𝐹𝑘) · (10↑𝑘)) − (𝐹𝑘)) = (Σ𝑘 ∈ (0...𝑁)((𝐹𝑘) · (10↑𝑘)) − Σ𝑘 ∈ (0...𝑁)(𝐹𝑘)))
8279, 81breqtrd 5065 . 2 ((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) → 3 ∥ (Σ𝑘 ∈ (0...𝑁)((𝐹𝑘) · (10↑𝑘)) − Σ𝑘 ∈ (0...𝑁)(𝐹𝑘)))
83 dvdssub2 15825 . 2 (((3 ∈ ℤ ∧ Σ𝑘 ∈ (0...𝑁)((𝐹𝑘) · (10↑𝑘)) ∈ ℤ ∧ Σ𝑘 ∈ (0...𝑁)(𝐹𝑘) ∈ ℤ) ∧ 3 ∥ (Σ𝑘 ∈ (0...𝑁)((𝐹𝑘) · (10↑𝑘)) − Σ𝑘 ∈ (0...𝑁)(𝐹𝑘))) → (3 ∥ Σ𝑘 ∈ (0...𝑁)((𝐹𝑘) · (10↑𝑘)) ↔ 3 ∥ Σ𝑘 ∈ (0...𝑁)(𝐹𝑘)))
842, 13, 14, 82, 83syl31anc 1375 1 ((𝑁 ∈ ℕ0𝐹:(0...𝑁)⟶ℤ) → (3 ∥ Σ𝑘 ∈ (0...𝑁)((𝐹𝑘) · (10↑𝑘)) ↔ 3 ∥ Σ𝑘 ∈ (0...𝑁)(𝐹𝑘)))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 209  wa 399   = wceq 1543  wcel 2112  wne 2932   class class class wbr 5039  wf 6354  cfv 6358  (class class class)co 7191  cc 10692  0cc0 10694  1c1 10695   + caddc 10697   · cmul 10699  cmin 11027  -cneg 11028   / cdiv 11454  3c3 11851  9c9 11857  0cn0 12055  cz 12141  cdc 12258  ...cfz 13060  cexp 13600  Σcsu 15214  cdvds 15778
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1803  ax-4 1817  ax-5 1918  ax-6 1976  ax-7 2018  ax-8 2114  ax-9 2122  ax-10 2143  ax-11 2160  ax-12 2177  ax-ext 2708  ax-rep 5164  ax-sep 5177  ax-nul 5184  ax-pow 5243  ax-pr 5307  ax-un 7501  ax-inf2 9234  ax-cnex 10750  ax-resscn 10751  ax-1cn 10752  ax-icn 10753  ax-addcl 10754  ax-addrcl 10755  ax-mulcl 10756  ax-mulrcl 10757  ax-mulcom 10758  ax-addass 10759  ax-mulass 10760  ax-distr 10761  ax-i2m1 10762  ax-1ne0 10763  ax-1rid 10764  ax-rnegex 10765  ax-rrecex 10766  ax-cnre 10767  ax-pre-lttri 10768  ax-pre-lttrn 10769  ax-pre-ltadd 10770  ax-pre-mulgt0 10771  ax-pre-sup 10772
This theorem depends on definitions:  df-bi 210  df-an 400  df-or 848  df-3or 1090  df-3an 1091  df-tru 1546  df-fal 1556  df-ex 1788  df-nf 1792  df-sb 2073  df-mo 2539  df-eu 2568  df-clab 2715  df-cleq 2728  df-clel 2809  df-nfc 2879  df-ne 2933  df-nel 3037  df-ral 3056  df-rex 3057  df-reu 3058  df-rmo 3059  df-rab 3060  df-v 3400  df-sbc 3684  df-csb 3799  df-dif 3856  df-un 3858  df-in 3860  df-ss 3870  df-pss 3872  df-nul 4224  df-if 4426  df-pw 4501  df-sn 4528  df-pr 4530  df-tp 4532  df-op 4534  df-uni 4806  df-int 4846  df-iun 4892  df-br 5040  df-opab 5102  df-mpt 5121  df-tr 5147  df-id 5440  df-eprel 5445  df-po 5453  df-so 5454  df-fr 5494  df-se 5495  df-we 5496  df-xp 5542  df-rel 5543  df-cnv 5544  df-co 5545  df-dm 5546  df-rn 5547  df-res 5548  df-ima 5549  df-pred 6140  df-ord 6194  df-on 6195  df-lim 6196  df-suc 6197  df-iota 6316  df-fun 6360  df-fn 6361  df-f 6362  df-f1 6363  df-fo 6364  df-f1o 6365  df-fv 6366  df-isom 6367  df-riota 7148  df-ov 7194  df-oprab 7195  df-mpo 7196  df-om 7623  df-1st 7739  df-2nd 7740  df-wrecs 8025  df-recs 8086  df-rdg 8124  df-1o 8180  df-er 8369  df-en 8605  df-dom 8606  df-sdom 8607  df-fin 8608  df-sup 9036  df-oi 9104  df-card 9520  df-pnf 10834  df-mnf 10835  df-xr 10836  df-ltxr 10837  df-le 10838  df-sub 11029  df-neg 11030  df-div 11455  df-nn 11796  df-2 11858  df-3 11859  df-4 11860  df-5 11861  df-6 11862  df-7 11863  df-8 11864  df-9 11865  df-n0 12056  df-z 12142  df-dec 12259  df-uz 12404  df-rp 12552  df-fz 13061  df-fzo 13204  df-seq 13540  df-exp 13601  df-hash 13862  df-cj 14627  df-re 14628  df-im 14629  df-sqrt 14763  df-abs 14764  df-clim 15014  df-sum 15215  df-dvds 15779
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator