در یک سیستم نرمافزاری، تعدادی پردازه در حال اجرا هستند. دو پردازه برای پیشبرد کار خود ممکن است مستقیما با هم ارتباط برقرار کنند(همهی ارتباطها دو طرفهاند). اگر یک پردازه را بکشیم، همهی پردازهها زندهای که در آن لحظه به طور مستقیم یا غیر مستقیم (از طریق یک یا چند پردازهی زندهی میانی) با پردازهی کشته شده ارتباط داشتهاند، یک پیغام خطا به مدیر سیستم میفرستند. میخواهیم همهی پردازهها را بکشیم به نحوی که تعداد پیغام خطاهایی که به مدیر سیستم فرستاده میشود کمینه شود.
برنامهای بنویسید که:
اندازهی ورودیهایی که برای نمرهدهی به برنامهی شما داده میشود در جدول زیر آمده است. البته بعضی از این تستها باهم در یک گروه قرار دارند و در مجموع ۲۰ گروه تست وجود دارد.
شما میتوانید نتیجهی تستهایی که با علامت ستاره مشخص شدهاند را در طول امتحان مشاهده کنید.
در سطر اول خروجی، کمترین تعداد پیغام خطایی را بنویسید که برای کشتن همهی پردازهها فرستاده میشود. در سطر دوم، شمارهی $n$ پردازه را با فاصله از هم به ترتیبی بنویسید که کشتن پردازهها به آن ترتیب، تعداد پیغامهای خطا را کمینه میکند.