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

Theorem friendship 30479
Description: The friendship theorem: In every finite (nonempty) friendship graph there is a vertex which is adjacent to all other vertices. This is Metamath 100 proof #83. (Contributed by Alexander van der Vekens, 9-Oct-2018.)
Hypothesis
Ref Expression
friendship.v 𝑉 = (Vtx‘𝐺)
Assertion
Ref Expression
friendship ((𝐺 ∈ FriendGraph ∧ 𝑉 ≠ ∅ ∧ 𝑉 ∈ Fin) → ∃𝑣𝑉𝑤 ∈ (𝑉 ∖ {𝑣}){𝑣, 𝑤} ∈ (Edg‘𝐺))
Distinct variable groups:   𝑣,𝐺,𝑤   𝑣,𝑉,𝑤

Proof of Theorem friendship
Dummy variables 𝑎 𝑏 𝑐 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 simpr1 1196 . . . 4 ((3 < (♯‘𝑉) ∧ (𝐺 ∈ FriendGraph ∧ 𝑉 ≠ ∅ ∧ 𝑉 ∈ Fin)) → 𝐺 ∈ FriendGraph )
2 simpr3 1198 . . . 4 ((3 < (♯‘𝑉) ∧ (𝐺 ∈ FriendGraph ∧ 𝑉 ≠ ∅ ∧ 𝑉 ∈ Fin)) → 𝑉 ∈ Fin)
3 simpl 482 . . . 4 ((3 < (♯‘𝑉) ∧ (𝐺 ∈ FriendGraph ∧ 𝑉 ≠ ∅ ∧ 𝑉 ∈ Fin)) → 3 < (♯‘𝑉))
4 friendship.v . . . . 5 𝑉 = (Vtx‘𝐺)
54friendshipgt3 30478 . . . 4 ((𝐺 ∈ FriendGraph ∧ 𝑉 ∈ Fin ∧ 3 < (♯‘𝑉)) → ∃𝑣𝑉𝑤 ∈ (𝑉 ∖ {𝑣}){𝑣, 𝑤} ∈ (Edg‘𝐺))
61, 2, 3, 5syl3anc 1374 . . 3 ((3 < (♯‘𝑉) ∧ (𝐺 ∈ FriendGraph ∧ 𝑉 ≠ ∅ ∧ 𝑉 ∈ Fin)) → ∃𝑣𝑉𝑤 ∈ (𝑉 ∖ {𝑣}){𝑣, 𝑤} ∈ (Edg‘𝐺))
76ex 412 . 2 (3 < (♯‘𝑉) → ((𝐺 ∈ FriendGraph ∧ 𝑉 ≠ ∅ ∧ 𝑉 ∈ Fin) → ∃𝑣𝑉𝑤 ∈ (𝑉 ∖ {𝑣}){𝑣, 𝑤} ∈ (Edg‘𝐺)))
8 hashcl 14284 . . . . . . . . 9 (𝑉 ∈ Fin → (♯‘𝑉) ∈ ℕ0)
9 simplr 769 . . . . . . . . . . 11 ((((♯‘𝑉) ∈ ℕ0𝑉 ∈ Fin) ∧ (¬ 3 < (♯‘𝑉) ∧ 𝑉 ≠ ∅)) → 𝑉 ∈ Fin)
10 hashge1 14317 . . . . . . . . . . . 12 ((𝑉 ∈ Fin ∧ 𝑉 ≠ ∅) → 1 ≤ (♯‘𝑉))
1110ad2ant2l 747 . . . . . . . . . . 11 ((((♯‘𝑉) ∈ ℕ0𝑉 ∈ Fin) ∧ (¬ 3 < (♯‘𝑉) ∧ 𝑉 ≠ ∅)) → 1 ≤ (♯‘𝑉))
12 nn0re 12415 . . . . . . . . . . . . . . . . 17 ((♯‘𝑉) ∈ ℕ0 → (♯‘𝑉) ∈ ℝ)
13 3re 12230 . . . . . . . . . . . . . . . . 17 3 ∈ ℝ
14 lenlt 11216 . . . . . . . . . . . . . . . . 17 (((♯‘𝑉) ∈ ℝ ∧ 3 ∈ ℝ) → ((♯‘𝑉) ≤ 3 ↔ ¬ 3 < (♯‘𝑉)))
1512, 13, 14sylancl 587 . . . . . . . . . . . . . . . 16 ((♯‘𝑉) ∈ ℕ0 → ((♯‘𝑉) ≤ 3 ↔ ¬ 3 < (♯‘𝑉)))
1615biimprd 248 . . . . . . . . . . . . . . 15 ((♯‘𝑉) ∈ ℕ0 → (¬ 3 < (♯‘𝑉) → (♯‘𝑉) ≤ 3))
1716adantr 480 . . . . . . . . . . . . . 14 (((♯‘𝑉) ∈ ℕ0𝑉 ∈ Fin) → (¬ 3 < (♯‘𝑉) → (♯‘𝑉) ≤ 3))
1817com12 32 . . . . . . . . . . . . 13 (¬ 3 < (♯‘𝑉) → (((♯‘𝑉) ∈ ℕ0𝑉 ∈ Fin) → (♯‘𝑉) ≤ 3))
1918adantr 480 . . . . . . . . . . . 12 ((¬ 3 < (♯‘𝑉) ∧ 𝑉 ≠ ∅) → (((♯‘𝑉) ∈ ℕ0𝑉 ∈ Fin) → (♯‘𝑉) ≤ 3))
2019impcom 407 . . . . . . . . . . 11 ((((♯‘𝑉) ∈ ℕ0𝑉 ∈ Fin) ∧ (¬ 3 < (♯‘𝑉) ∧ 𝑉 ≠ ∅)) → (♯‘𝑉) ≤ 3)
219, 11, 203jca 1129 . . . . . . . . . 10 ((((♯‘𝑉) ∈ ℕ0𝑉 ∈ Fin) ∧ (¬ 3 < (♯‘𝑉) ∧ 𝑉 ≠ ∅)) → (𝑉 ∈ Fin ∧ 1 ≤ (♯‘𝑉) ∧ (♯‘𝑉) ≤ 3))
2221exp31 419 . . . . . . . . 9 ((♯‘𝑉) ∈ ℕ0 → (𝑉 ∈ Fin → ((¬ 3 < (♯‘𝑉) ∧ 𝑉 ≠ ∅) → (𝑉 ∈ Fin ∧ 1 ≤ (♯‘𝑉) ∧ (♯‘𝑉) ≤ 3))))
238, 22mpcom 38 . . . . . . . 8 (𝑉 ∈ Fin → ((¬ 3 < (♯‘𝑉) ∧ 𝑉 ≠ ∅) → (𝑉 ∈ Fin ∧ 1 ≤ (♯‘𝑉) ∧ (♯‘𝑉) ≤ 3)))
2423impcom 407 . . . . . . 7 (((¬ 3 < (♯‘𝑉) ∧ 𝑉 ≠ ∅) ∧ 𝑉 ∈ Fin) → (𝑉 ∈ Fin ∧ 1 ≤ (♯‘𝑉) ∧ (♯‘𝑉) ≤ 3))
25 hash1to3 14420 . . . . . . 7 ((𝑉 ∈ Fin ∧ 1 ≤ (♯‘𝑉) ∧ (♯‘𝑉) ≤ 3) → ∃𝑎𝑏𝑐(𝑉 = {𝑎} ∨ 𝑉 = {𝑎, 𝑏} ∨ 𝑉 = {𝑎, 𝑏, 𝑐}))
26 vex 3445 . . . . . . . . . 10 𝑎 ∈ V
27 eqid 2737 . . . . . . . . . . 11 (Edg‘𝐺) = (Edg‘𝐺)
284, 271to3vfriendship 30361 . . . . . . . . . 10 ((𝑎 ∈ V ∧ (𝑉 = {𝑎} ∨ 𝑉 = {𝑎, 𝑏} ∨ 𝑉 = {𝑎, 𝑏, 𝑐})) → (𝐺 ∈ FriendGraph → ∃𝑣𝑉𝑤 ∈ (𝑉 ∖ {𝑣}){𝑣, 𝑤} ∈ (Edg‘𝐺)))
2926, 28mpan 691 . . . . . . . . 9 ((𝑉 = {𝑎} ∨ 𝑉 = {𝑎, 𝑏} ∨ 𝑉 = {𝑎, 𝑏, 𝑐}) → (𝐺 ∈ FriendGraph → ∃𝑣𝑉𝑤 ∈ (𝑉 ∖ {𝑣}){𝑣, 𝑤} ∈ (Edg‘𝐺)))
3029exlimiv 1932 . . . . . . . 8 (∃𝑐(𝑉 = {𝑎} ∨ 𝑉 = {𝑎, 𝑏} ∨ 𝑉 = {𝑎, 𝑏, 𝑐}) → (𝐺 ∈ FriendGraph → ∃𝑣𝑉𝑤 ∈ (𝑉 ∖ {𝑣}){𝑣, 𝑤} ∈ (Edg‘𝐺)))
3130exlimivv 1934 . . . . . . 7 (∃𝑎𝑏𝑐(𝑉 = {𝑎} ∨ 𝑉 = {𝑎, 𝑏} ∨ 𝑉 = {𝑎, 𝑏, 𝑐}) → (𝐺 ∈ FriendGraph → ∃𝑣𝑉𝑤 ∈ (𝑉 ∖ {𝑣}){𝑣, 𝑤} ∈ (Edg‘𝐺)))
3224, 25, 313syl 18 . . . . . 6 (((¬ 3 < (♯‘𝑉) ∧ 𝑉 ≠ ∅) ∧ 𝑉 ∈ Fin) → (𝐺 ∈ FriendGraph → ∃𝑣𝑉𝑤 ∈ (𝑉 ∖ {𝑣}){𝑣, 𝑤} ∈ (Edg‘𝐺)))
3332exp31 419 . . . . 5 (¬ 3 < (♯‘𝑉) → (𝑉 ≠ ∅ → (𝑉 ∈ Fin → (𝐺 ∈ FriendGraph → ∃𝑣𝑉𝑤 ∈ (𝑉 ∖ {𝑣}){𝑣, 𝑤} ∈ (Edg‘𝐺)))))
3433com14 96 . . . 4 (𝐺 ∈ FriendGraph → (𝑉 ≠ ∅ → (𝑉 ∈ Fin → (¬ 3 < (♯‘𝑉) → ∃𝑣𝑉𝑤 ∈ (𝑉 ∖ {𝑣}){𝑣, 𝑤} ∈ (Edg‘𝐺)))))
35343imp 1111 . . 3 ((𝐺 ∈ FriendGraph ∧ 𝑉 ≠ ∅ ∧ 𝑉 ∈ Fin) → (¬ 3 < (♯‘𝑉) → ∃𝑣𝑉𝑤 ∈ (𝑉 ∖ {𝑣}){𝑣, 𝑤} ∈ (Edg‘𝐺)))
3635com12 32 . 2 (¬ 3 < (♯‘𝑉) → ((𝐺 ∈ FriendGraph ∧ 𝑉 ≠ ∅ ∧ 𝑉 ∈ Fin) → ∃𝑣𝑉𝑤 ∈ (𝑉 ∖ {𝑣}){𝑣, 𝑤} ∈ (Edg‘𝐺)))
377, 36pm2.61i 182 1 ((𝐺 ∈ FriendGraph ∧ 𝑉 ≠ ∅ ∧ 𝑉 ∈ Fin) → ∃𝑣𝑉𝑤 ∈ (𝑉 ∖ {𝑣}){𝑣, 𝑤} ∈ (Edg‘𝐺))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wb 206  wa 395  w3o 1086  w3a 1087   = wceq 1542  wex 1781  wcel 2114  wne 2933  wral 3052  wrex 3061  Vcvv 3441  cdif 3899  c0 4286  {csn 4581  {cpr 4583  {ctp 4585   class class class wbr 5099  cfv 6493  Fincfn 8888  cr 11030  1c1 11032   < clt 11171  cle 11172  3c3 12206  0cn0 12406  chash 14258  Vtxcvtx 29074  Edgcedg 29125   FriendGraph cfrgr 30338
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1797  ax-4 1811  ax-5 1912  ax-6 1969  ax-7 2010  ax-8 2116  ax-9 2124  ax-10 2147  ax-11 2163  ax-12 2185  ax-ext 2709  ax-rep 5225  ax-sep 5242  ax-nul 5252  ax-pow 5311  ax-pr 5378  ax-un 7683  ax-inf2 9555  ax-cnex 11087  ax-resscn 11088  ax-1cn 11089  ax-icn 11090  ax-addcl 11091  ax-addrcl 11092  ax-mulcl 11093  ax-mulrcl 11094  ax-mulcom 11095  ax-addass 11096  ax-mulass 11097  ax-distr 11098  ax-i2m1 11099  ax-1ne0 11100  ax-1rid 11101  ax-rnegex 11102  ax-rrecex 11103  ax-cnre 11104  ax-pre-lttri 11105  ax-pre-lttrn 11106  ax-pre-ltadd 11107  ax-pre-mulgt0 11108  ax-pre-sup 11109
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 849  df-ifp 1064  df-3or 1088  df-3an 1089  df-tru 1545  df-fal 1555  df-ex 1782  df-nf 1786  df-sb 2069  df-mo 2540  df-eu 2570  df-clab 2716  df-cleq 2729  df-clel 2812  df-nfc 2886  df-ne 2934  df-nel 3038  df-ral 3053  df-rex 3062  df-rmo 3351  df-reu 3352  df-rab 3401  df-v 3443  df-sbc 3742  df-csb 3851  df-dif 3905  df-un 3907  df-in 3909  df-ss 3919  df-pss 3922  df-nul 4287  df-if 4481  df-pw 4557  df-sn 4582  df-pr 4584  df-tp 4586  df-op 4588  df-uni 4865  df-int 4904  df-iun 4949  df-disj 5067  df-br 5100  df-opab 5162  df-mpt 5181  df-tr 5207  df-id 5520  df-eprel 5525  df-po 5533  df-so 5534  df-fr 5578  df-se 5579  df-we 5580  df-xp 5631  df-rel 5632  df-cnv 5633  df-co 5634  df-dm 5635  df-rn 5636  df-res 5637  df-ima 5638  df-pred 6260  df-ord 6321  df-on 6322  df-lim 6323  df-suc 6324  df-iota 6449  df-fun 6495  df-fn 6496  df-f 6497  df-f1 6498  df-fo 6499  df-f1o 6500  df-fv 6501  df-isom 6502  df-riota 7318  df-ov 7364  df-oprab 7365  df-mpo 7366  df-om 7812  df-1st 7936  df-2nd 7937  df-frecs 8226  df-wrecs 8257  df-recs 8306  df-rdg 8344  df-1o 8400  df-2o 8401  df-3o 8402  df-oadd 8404  df-er 8638  df-ec 8640  df-qs 8644  df-map 8770  df-pm 8771  df-en 8889  df-dom 8890  df-sdom 8891  df-fin 8892  df-sup 9350  df-inf 9351  df-oi 9420  df-dju 9818  df-card 9856  df-pnf 11173  df-mnf 11174  df-xr 11175  df-ltxr 11176  df-le 11177  df-sub 11371  df-neg 11372  df-div 11800  df-nn 12151  df-2 12213  df-3 12214  df-n0 12407  df-xnn0 12480  df-z 12494  df-uz 12757  df-rp 12911  df-xadd 13032  df-ico 13272  df-fz 13429  df-fzo 13576  df-fl 13717  df-mod 13795  df-seq 13930  df-exp 13990  df-hash 14259  df-word 14442  df-lsw 14491  df-concat 14499  df-s1 14525  df-substr 14570  df-pfx 14600  df-reps 14697  df-csh 14717  df-s2 14776  df-s3 14777  df-cj 15027  df-re 15028  df-im 15029  df-sqrt 15163  df-abs 15164  df-clim 15416  df-sum 15615  df-dvds 16185  df-gcd 16427  df-prm 16604  df-phi 16698  df-vtx 29076  df-iedg 29077  df-edg 29126  df-uhgr 29136  df-ushgr 29137  df-upgr 29160  df-umgr 29161  df-uspgr 29228  df-usgr 29229  df-fusgr 29395  df-nbgr 29411  df-vtxdg 29545  df-rgr 29636  df-rusgr 29637  df-wlks 29678  df-wlkson 29679  df-trls 29769  df-trlson 29770  df-pths 29792  df-spths 29793  df-pthson 29794  df-spthson 29795  df-wwlks 29908  df-wwlksn 29909  df-wwlksnon 29910  df-wspthsn 29911  df-wspthsnon 29912  df-clwwlk 30062  df-clwwlkn 30105  df-clwwlknon 30168  df-conngr 30267  df-frgr 30339
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator