مسئلهٔ گراف کامل با برچسب‌های دودویی

روی هر یال از گراف کاملِ $2^n$ راسی، یکی از اعداد مجموعهٔ $\set{0, 1, 2, \ldots , 2^{\,n-1}-1}$ (یعنی یک عددِ $(n-1)$ بیتی) نوشته شده است. به‌طوری‌که در هر مثلث، مجموع دو یال برابرِ یال سوم است ثابت کنید در این گراف مثلثی وجود دارد که روی هر سه یال آن عدد صفر نوشته شده باشد. (امریکا ۲۰۰۲)


ایدهٔ اصلی: استقرا بر $n$

چرا استقرا در مسائل ترکیبیاتی چنین قدرتمند است؟

استقرا یکی از مؤثرترین ابزارهای حل مسئله است—به‌ویژه زمانی که ساختار مسئله در اندازه‌های مختلف «خویشاوند» باشد.

در مسائل گرافی با برچسب‌های عددی، معمولاً دو مسیر برای دیدن استقرا وجود دارد:

  1. پیدا کردن یک زیرگراف کوچک‌تر که همان شکل مسئله را (اما در اندازه کوچکتر) داشته باشد؛
  2. تبدیل کردن وزن‌ها (برچسب یال‌ها) به وزن‌هایی ساده‌تر،
    به‌گونه‌ای که باز هم همان شرط مسئله برقرار بماند.

در این مسئله نیز دقیقاً همین دو ایده را بررسی می‌کنیم.


تلاش اول: پیدا کردن زیرگراف مناسب برای فرض استقرا

می‌خواهیم فرض استقرا را درون حکم پیدا کنیم؛ یعنی زیرگرافی از گراف اصلی بسازیم که:

یک ایدهٔ طبیعی این است که یک رأس را درنظر بگیریم و به یال‌های متصل به آن نگاه کنیم.
تمام این یال‌ها یا مقدارشان کوچک است یعنی کوچک‌تر از $2^{n-2}$ هستند (بیتِ $n-1$ آن‌ها صفر است)

یا بزرگ است یعنی بزرگ‌تر یا مساوی $2^{n-2}$ هستند (بیتِ $n-1$ آن‌ها یک است).

اما مشکل اینجاست:

برای آن دسته از رأس‌هایی که با یال‌های کوچک به رأس اولیه وصل‌اند،
نمی‌توانیم به‌سادگی یک استدلال مشابه بسازیم.

و این شکاف باعث می‌شود این مسیر به نتیجهٔ مورد انتظار نرسد. به بیان دیگر، تقسیم رأس‌ها به دو دستهٔ «یال کوچک» و «یال بزرگ» فقط نیمهٔ ماجرا را کنترل می‌کند و نیمهٔ دیگر مهارناپذیر باقی می‌ماند.


تلاش دوم: کاهش بیت‌ها با تبدیل وزن‌ها

چگونه وزن‌های $(n-1)$ بیتی را به وزن‌های $(n-2)$ بیتی تبدیل کنیم؟

اگر بخواهیم یک زیرگراف با وزن‌های کوچک‌تر پیدا کنیم، می‌توانیم به جای انتخاب زیرمجموعهٔ رئوس، خود وزن‌ها را تبدیل کنیم:

سؤال طبیعی:
چطور می‌توان یکی از بیت‌های وزن‌ها را حذف کرد، بدون آن‌که شرط مسئله («در هر مثلث مجموع دو یال برابر سوم باشد») خراب شود؟

یک مشاهدهٔ کلیدی این است:

اگر عددی را بر ۲ تقسیم کنیم (شیفت به راست در دودویی)،
بیت سمت راست حذف می‌شود.
و از آن‌جا که اگر $a + b = c$ آن‌گاه $ \frac{a}{2} + \frac{b}{2} = \frac{c}{2}$،
هر شرطی از نوع «مجموعِ دو یال برابر یال سوم»
پس از تقسیم بر ۲ همچنان برقرار می‌ماند به شرطی که تمام وزن‌ها زوج باشند.

بنابراین اگر بتوانیم زیرگرافی پیدا کنیم که تمام وزن‌های یال‌های آن زوج‌ باشد و حداقل $2^{n-1} + 1$ راس داشته باشد می‌توانیم با خیال راحت وزن‌ها را نصف کنیم و یک گراف جدید بسازیم که:

این دقیقاً «دروازهٔ ورود» به فرض استقرا است.


گام کلیدی: جدا کردن یال‌های زوج و فرد

اکنون به سراغ ایدهٔ اصلی برای اجرای استقرا می‌رویم.

یک رأس دلخواه از گراف را در نظر بگیرید و آن را $v$ بنامید.
تمام یال‌های متصل به این رأس یا زوج هستند یا فرد.

بر این اساس، رأس‌های دیگر را به دو دسته تقسیم می‌کنیم:

این تقسیم‌بندی تمام رأس‌های گراف (به‌جز خود $v$) را پوشش می‌دهد.


یک مشاهدهٔ ساده اما تعیین‌کننده

ادعا می‌کنیم:

یال‌های میان راس‌های دسته‌ی اول و همچنین یال‌های میان راس‌های دستهٔ دوم، حتماً زوج‌اند.

چرا؟

فرض کنید $u$ و همچنین $w$ رأسی‌هایی باشند که یال $vu$ و $vw$ زوج است در مثلث $vuw$، طبق شرط مسئله، یکی از این سه رابطه برقرار است:

\[vu + vw = uw \quad \text{یا} \quad |vu - vw| = uw.\]

اما در هر دو حالت جمع یا تفاضل دو عدد زوج زوج است. (مانند همین استدلال برای جمع یا تفاضل دو عدد فرد نیز برقرار است).


انتخاب زیرگراف مناسب برای استقرا

اکنون به تعداد رأس‌ها نگاه می‌کنیم.

اگر تعداد رأس‌هایی که با یال فرد به $v$ وصل‌اند
بیش از $\;2^{n-1}$ باشد،
زیرگراف القایی روی این رأس‌ها دارای:

در این صورت، زیرگراف مناسب برای استقرا را پیدا کرده‌ایم.

و اگر چنین نباشد؟

یعنی اگر تعداد رأس‌های متصل با یال فرد کمتر یا مساوی $2^{n-1}$ باشد،
آن‌گاه تعداد رأس‌های متصل با یال زوج حداقل $2^{n-1}$ است.

در این حالت، رأس $v$ را نیز به این مجموعه اضافه می‌کنیم.
در نتیجه مجموعه‌ای با دست‌کم:

\[2^{n-1} + 1\]

رأس به‌دست می‌آوریم که:


نتیجهٔ این گام

در هر دو حالت، موفق شده‌ایم زیرگرافی با:

پیدا کنیم.

اکنون می‌توانیم وزن تمام یال‌های این زیرگراف را بر ۲ تقسیم کنیم؛
با این کار:

در گام بعد، با اعمال فرض استقرا روی این زیرگراف، به وجود یک مثلث با یال‌های صفر می‌رسیم، مثلث صفر در زیرگراف با وزن‌های جدید مثلث صفر در گراف اصلی را نتیجه می‌دهد چرا که $0 \times 2 = 0$ و اثبات کامل می‌شود.


جمع‌بندی

در این مسئله، با گراف کاملی سروکار داشتیم که یال‌های آن با عددهای دودویی برچسب‌گذاری شده بودند و شرطی محلی اما بسیار قوی روی هر مثلث برقرار بود:
در هر مثلث، یکی از یال‌ها برابر مجموع دو یال دیگر است.

کلید حل مسئله، دیدن ساختار استقراییِ پنهان در دل همین شرط محلی بود. ابتدا تلاش کردیم با پیدا کردن یک زیرگراف مناسب مستقیماً فرض استقرا را بیابیم، اما دیدیم که تقسیم سادهٔ یال‌ها به «بزرگ» و «کوچک» تنها نیمی از مسئله را مهار می‌کند.

در گام بعد، با تغییر زاویهٔ نگاه، به‌جای انتخاب زیرگراف، خودِ وزن‌ها را هدف قرار دادیم. ایدهٔ تعیین‌کننده این بود که اگر بتوانیم مجموعه‌ای بزرگ از رأس‌ها پیدا کنیم که تمام یال‌های میان آن‌ها زوج باشند، می‌توانیم با نصف‌کردن وزن‌ها یک گراف جدید بسازیم که دقیقاً شکل فرض استقرا را دارد.

تقسیم رأس‌ها بر اساس زوج یا فرد بودن یال‌های متصل به یک رأس ثابت و استفاده از شرط مسئله روی مثلث‌ها، به ما اجازه داد چنین زیرگرافی را با حداقل $2^{n-1}+1$ رأس پیدا کنیم. پس از آن، با نصف‌کردن وزن‌ها و اعمال فرض استقرا، به وجود یک مثلث با یال‌های صفر رسیدیم.