You are not allowed to perform this action

Network

شما تعدادی رایانه دارید که می‌خواهید با استفاده از کابل آن‌ها را به‌هم وصل کنید.

برای اتصال همه رایانه‌ها به‌یکدیگر کافیست هر دو رایانه بتوانند با استفاده از یک مسیر به هم ارتباط برقرار کنند. به ازای هر دو رایانه اندازه کابلی که لازم است تا آن ها را به هم متصل کنیم را داریم.

ما فقط دو نوع کابل نوع $0$ و نوع $1$ داریم ، که هزینه هر متر آن‌ها به ترتیب $p_0$ و $p_1$ است و از هر کدام به ترتیب $q_0$ و $q_1$ متر در بازار موجود است. همچنین هر کابلی که دو رایانه را به هم متصل می‌کند باید کاملاً از یک نوع باشد.

شما باید کم‌ترین هزینه‌ای را به دست بیاورید که با استفاده از آن می‌توان رایانه‌ها را به هم متصل کرد.

ورودی

  • در سطر اول ورودی دو عدد $1 \leq n \leq 10^3$ و $1 \leq m \leq 10^4$ نشان‌دهنده تعداد رایانه‌ها و تعداد جفت رایانه‌هایی که می‌توان آن‌ها را با سیم مستقیماً به‌هم متصل کرد، آمد است.
  • در $m$ سطر بعد در هر سطر سه عدد $1 \leq a_i,b_i \leq n$ و $ 0 \leq c_i \leq 100$ آمده است که نشان می‌دهد می‌توان دو رایانه $a_i$ و $b_i$ را با کابل به اندازه $c_i$ به‌هم متصل کنیم.
  • در سطر آخر ورودی چهار عدد $1 \leq p_0 وq_0,p_1 وq_1 \leq 10^5$ به ترتیب آمده است.

خروجی

در تنها سطر خروجی پاسخ سؤال را چاپ نمایید، در صورتی که این کار امکان‌پذیر نیست در خروجی Impossible چاپ کنید.

محدودیت‌ها

  • محدودیت زمان: ۴ ثانیه
  • محدودیت حافظه: ۲۵۶ مگابایت

ورودی و خروجی نمونه

ورودی نمونه خروجی نمونه
6 7
1 2 7
2 6 5
1 4 8
2 3 5
3 4 5
5 6 6
3 5 3
2 11 3 100
65

پاسخ

ادعا می‌کنیم که‌یال‌های جواب یک زیردرخت فراگیر کمینه (MST) می‌سازند. بدیهی است که جواب بهینه‌یک درخت است وگرنه دور دارد و می‌توان یک یال را حذف کرد و هزینه کم‌تر شود. حال ثابت می‌کنیم که جواب بهینه‌یک MST هم هست. کوتاه‌ترین یالی که در MST آمده و در جواب بهینه‌ی ما نیست را در نظر می‌گیریم و $e$ می‌نامیم. $e$ را به جواب بهینه اضافه کرده و طولانی‌ترین یالی که با $e$ در یک دور قرار دارد را حذف می‌کنیم تا به‌یک درخت جدید برسیم. بدیهی است که می‌توان درخت جدید را مشابه جواب بهینه با سیم‌ها بپوشانیم، با این تفاوت که به جای اینکه‌یال حذف شده را بپوشانیم، $e$ را می‌پوشانیم. (طول $e$ کم‌تر از یال حذف شده است زیرا اگر یال حذف شده کوتاه‌تر از e بود در دوری که با $e$ تشکیل داده اند، همه‌یال‌ها کوتاه تر از $e$ بودند و چون همه‌یال‌های کوتاه تر از $e$ در MST آمده‌اند در MST اولیه دور داشته‌ایم که تناقض است(! پس اگر با سیم‌های موجود می‌توانستیم جواب بهینه را سیم‌کشی کنیم درخت جدید را هم می‌توانیم و چون طول $e$ کم‌تر است، هزینه کل درخت جدید از هزینه کل جواب بهینه کم‌تر است که تناقض است پس جواب بهینه‌یک MST است. پیدا کردن یک MST از $O(e \log n)$ است که می‌توان با الگوریتم‌هایی نظیر kruskal یا prim آن را بدست آورد.

بدون اینکه به کلیت مسئله لطمه وارد شود می‌توان فرض کرد که $p_0< p_1$ است. از آنجا که مجموع طول یال‌های MST ثابت است بدیهی است که در جواب بهینه بیش‌ترین مقدار ممکن که می‌توان را با سیم‌های $p_0$ پوشانده‌ایم و باقی را به ناچار با $p_1$ یعنی بین دو جواب، جوابی که مقدار بیش‌تری از $p_0$ استفاده کرده‌ایم بهتر است. حال مسئله به این تبدیل می‌شود که $n-1$ شی با اندازه‌های $L_i$ (وزن یال $i$ ام در (MST داریم و می‌خواهیم بیش‌ترین مقدار از آن‌ها (از لحاظ مجموع وزن)‌ را درون یک کیسه با اندازه $q_0$ جا دهیم. این مسئله به knapsack یا مسئله کوله پشتی معروف است که به صورت پویا از $O(q_0 n)$ حل میشود.

▸ سوال قبل سوال بعد ◂