فرض کنید T1 و T2 دو درخت ریشهدار باشند که در هرکدام به هر راس یک عدد به نشانهی برچسب آن راس نسبت داده شده باشد و هر راس حداکثر دو فرزند داشته باشد. درخت T1 زیردرخت T2 است اگر نگاشت یکبهیک f از مجموعه راسهای T1 به مجموعه راسهای T2 وجود داشته باشد به طوری که:
برنامهای بنویسید که kدرخت T2،T1،… و Tk با شرایط گفته شده را از ورودی دریافت کند و تعیین کند که کدام یک زیردرخت دیگری است.
خط نخست فایل ورودی شامل عدد k است. درخطوط بعدی، مشخصات درختها به ترتیب به شکل ذیل آمده است. مشخصات هر درخت n راسی در n+1 خط توصیف میشود: خط اول n و شمارهی راس ریشهی درخت، خط دوم n عدد به نشانهی برچسب راسها با حفظ ترتیب و n−1 خط بعد نیمهی فوقانی ماتریس مجاورت گراف را در بر دارد.
در فایل خروجی ماتریس Mn×n را در n خط با لحاظ فاصله بین درایههای هر سطر آن چاپ کنید. اگر درخت Ti زیردرخت درخت Tj باشد، درایهی Mij را برابر یک و در غیر این صورت، برابر صفر قرار دهید. فرض کنید مقادیر n و k از ۱۰۰ بیشتر نیست. برچسب راسها هم از بین اعداد قابل ذخیرهسازی در یک متغیر از نوع Integer انتخاب میشوند.