کویر


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

مولین که به دنبال موجودات افسانه‌ای می‌گردد پا به سرزمین‌های خطرناک گذاشته و اکنون در وسط کویر مصر گیر افتاده‌است. او دیگر از نجات پیدا کردن نا امید شده بود که ناگهان یک کوتوله‌ی سبز رنگ او را پیدا می‌کند! کوتوله به او می‌گوید که می‌تواند یا جادوی خود او را به خانه منتقل کند ولی در صورتی این کار را می‌کند که مولین مساله زیر را برای او حل کند.

یک جدول n×mn \times m به شما داده می‌شود که در تقاطع سطر ii ام و ستون jj ام ai,ja_{i,j} نوشته شده است. به چند طریق می‌توان برای هر سطر و هر ستون عددی طبیعی انتخاب کرد به طوری که عدد هر خانه برابر با حاصل ضرب عدد سطر آن در ستون آن باشد؟

مولین که مهارت مثال نزدنی‌ای در سوال‌های المپیاد کامپیوتر دارد فورا مساله را حل کرده و به کمک جادو به خانه اش بر‌می‌گردد. او پس از برگشت به خانه این سوال را برای امتحان برنزکات پیشنهاد می‌دهد. اکنون وظیفه شما است که این مساله را حل کنید.

ورودی🔗

در خط اول ورودی دو عدد n n و m m آمده است که به ترتیب تعداد سطرها و ستون‌ها را نشان می‌دهد. در هر یک از n n خط بعدی m m عدد آمده که j j امین عدد در خط i i ام نشان‌دهنده عدد داخل خانه سطر i i ام و ستون j j ام جدول است. 1n,m1 0001 \le n, m \le 1\ 000

1ai,j10121 \le a_{i,j} \le 10^{12}

خروجی🔗

در تنها خط خروجی, جواب مساله را چاپ کنید.

زیرمسئله‌ها🔗

زیرمسئله نمره محدودیت
۱ ۷ n=m=1n=m=1
۲ ۱۱ ai2a_i \le 2
۳ ۴۵ ai1 000a_i \le 1\ 000
۴ ۳۷ بدون محدودیت اضافی

مثال🔗

ورودی نمونه ۱🔗

2 3
2 6 6
6 18 18
Plain text

خروجی نمونه ۱🔗

2
Plain text

هیتایوتا


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

کشور هیتایوتا از n n شهر با شماره‌های 0 0 تا n1 n - 1 تشکیل شده و جاده‌های آن به شکل یک n n ضلعی منتظم است. پادشاه برای رفاه حال مردم m m جاده دیگر ساخته است تا مردم بتوانند از این n+m n + m جاده برای رفت و آمد خود استفاده کنند. (هر جاده دو شهر را با یک خط صاف به هم دیگر وصل می‌کند.)

کشور متناظر با ورودی نمونه؛ کشوری با ۴ شهر که دو جاده دیگر در آن ساخته‌شده‌است.

پادشاه خیلی زود متوجه شد که نگه‌داری از این جاده‌ها کار بسیار هزینه‌بری است. برای همین او می‌خواهد تعدادی از جاده‌ها را خراب کند به صورتی که برای جاده‌های باقی‌مانده دو خاصیت زیر برقرار باشد:

  • بین هر دو شهر دقیقا یک مسیر وجود داشته باشد.
  • هیچ دو جاده‌ای یک‌دیگر را (جز در نقطه شروع و پایان) قطع نکنند.

پادشاه می‌خواد بداند با محدودیت‌های بالا به چند روش می‌تواند جاده‌ها را خراب کند. دو روش متفاوت است اگر و تنها اگر جاده‌ای وجود داشته باشد که در یکی از آن‌ها خراب شده باشد و در دیگری خراب نشده باشد. از آن‌جایی که این عدد می‌تواند خیلی بزرگ باشد پادشاه می‌خواد بداند باقی‌مانده تقسیم این عدد بر 109+710^9 + 7 چند است.

ورودی🔗

در خط اول ورودی دو عدد n n و m m آمده است که تعداد شهرها و تعداد جاده‌های اضافه شده را نشان می‌دهد.

در m m خط بعدی در هر خط دو عدد u u و v v آمده است که نشان‌دهنده جاده‌ای بین شهر u u و v v است.

3n200 3 \le n \le 200

0mn×(n3)20 \le m \le \frac{n \times (n-3)}{2}

0ui,vin10 \le u_i, v_i \le n-1

بین هر دو شهر حداکثر یک جاده (از بین n+m n + m جاده) وجود دارد و هیچ جاده‌ای یک شهر را به خودش وصل نمی‌کند.

خروجی🔗

در تنها خط خروجی، عدد مورد نظر پادشاه را چاپ کنید.

زیرمسئله‌ها🔗

زیرمسئله نمره محدودیت
۱ ۱۳ n7 n \le 7
۲ ۲۱ یک سر جاده‌های اضافه شده، شهر با شماره 00 است.
۳ ۶۶ بدون محدودیت اضافی

مثال🔗

ورودی نمونه🔗

4 2
0 2
1 3
Plain text

خروجی نمونه🔗

12
Plain text

بازی


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

اشکان برای سرگرم کردن پرهام یک بازی طراحی کرده‌است. او به پرهام یک جایگشت از اعداد صفر تا n1n-1 می‌دهد و از او می‌خواهد که با کمترین تعداد حرکت این جایگشت را مرتب کند.

پرهام در هر نوبت می‌تواند جایگشت را به دو زیردنباله S1S_1 و S2S_2 افراز کند و جایگشت جدید را از کنار هم گذاشتن S1S_1 و S2S_2 به دست آورد. برای مثال او می‌تواند در یک نوبت جایگشت <1,3,2,0,4,5><1, 3, 2, 0, 4, 5> را به دو زیردنباله <3,0,4,5><3, 0, 4, 5> و <1,2><1, 2> افراز کند و سپس به جایگشت <3,0,4,5,1,2><3, 0, 4, 5, 1, 2> تبدیل کند. توجه کنید که اعضای زیردنباله به همان ترتیبی که در جایگشت هستند باید قرار گیرند، مثلا <3,4,0><3, 4, 0> زیردنباله معتبری از جایگشت داده شده نیست.

به پرهام کمک کنید که با کمترین تعداد حرکت جایگشت داده شده را مرتب کند. 1n100 0001 \le n \le 100\ 000 0pin10 \le p_i \le n-1

ورودی🔗

در خط اول ورودی عدد n n آمده است. در خط بعد nn عدد p0,p1,...,pn1 p_0, p_1, ... , p_{n-1} آمده که اعداد جایگشت هستند.

خروجی🔗

در خط اول خروجی kk، کمترین تعداد حرکت‌ مورد نیاز را چاپ کنید.

در هر یک k+1 k + 1 خط بعدی n n عدد چاپ کنید که خط اول خود جایگشت ورودی و پس از آن در هر خط جایگشتی که از روی جایگشت قبلی‌اش به دست می‌آید را چاپ کنید.

اگر بیش از یک روش برای مرتب کردن جایگشت با کمترین تعداد حرکت وجود داشته‌باشد می‌توانید هر کدام را به دلخواه چاپ کنید.

زیرمسئله‌ها🔗

زیرمسئله نمره محدودیت
۱ ۱۱ n7n \le 7
۲ ۲۳ جایگشت نزولی است (pi>pi+1p_i > p_{i+1}) و nn توانی از دو است یعنی n=2kn=2^k
۳ ۴۶ n100n \le 100
۴ ۲۰ بدون محدودیت اضافی

مثال🔗

ورودی نمونه ۱🔗

3
0 1 2
Plain text

خروجی نمونه ۱🔗

0
0 1 2
Plain text

ورودی نمونه ۲🔗

5
0 3 1 2 4
Plain text

خروجی نمونه ۲🔗

1
0 3 1 2 4 
0 1 2 3 4
Plain text

ورودی نمونه ۳🔗

6
1 3 2 0 4 5
Plain text

خروجی نمونه ۳🔗

2
1 3 2 0 4 5
3 0 4 5 1 2
0 1 2 3 4 5
Plain text