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

در کشور اسپادانا، مردم علاقه زیادی به تصوّف و صوفی‌ها دارند. به همین دلیل هر ساله در یک روز به خصوص صوفی‌ها یک نمایش در جهت هدایت همگانی اجرا می‌کنند.
در این کشور nn صوفی زندگی می‌کنند که با شماره‌های 11 تا nn مشخص می‌شوند. هر صوفی یک مُراد دارد و مراد صوفی ii اُم، صوفی i1i - 1 اُم است و مراد صوفی شماره 11 نیز خداست.
این nn‌ صوفی در یک خط نمایش را اجرا می‌کنند. این خط n+1n+1 جایگاه دارد که با شماره‌های 00 تا nn از چپ به راست شماره‌گذاری شده‌اند. در ابتدا صوفی‌ها در جایگاه‌های 1,2,...,n1, 2, ..., n قرار دارند به طوری هیچ دو صوفی‌ای در یک جایگاه نیستند. در این نمایش نمادین، خدا همواره در جایگاه صفر خط قرار دارد.
این نمایش به این شکل انجام می‌شود که در هر مرحله دو بار تفنگ شلیک می‌شود.

  • با شلیک اول تفنگ، هر صوفی به مرادش نگاه می‌کند جایگاه او را به خاطر می‌سپارد، سپس اگر جایگاه مرادش سمت چپش بود، تصمیم می‌گیرد که یک واحد به چپ برود، اگر جایگاه مرادش با جایگاه خودش یکسان بود، تصمیم می‌گیرد که حرکتی نکند و اگر مرادش سمت راست او بود، تصمیم می‌گیرد یک واحد به راست برود.

  • با شلیک دوم تفنگ، هر صوفی حرکتی که در مرحله قبلی مدنظر داشت را انجام می‌دهد. (ممکن است در جایش باقی بماند)

نمایش وقتی پایان می‌یابد که همه صوفی‌ها در جایگاه صفر قرار بگیرند و به مراد واقعی‌شان برسند. دقت کنید در حین این مراحل، ممکن است در یک جایگاه بیش‌ از یک صوفی قرار بگیرند.
به عنوان مثال فرض کنید جایگاه ابتدایی صوفی‌ها به شکل زیر باشد، مراحل به این صورت خواهد بود. (خدا را با عدد صفر نمایش داده‌ایم)

< 0  3  1  2 >  < 0  1  2,3  >  < 0,1  2  3  >  < 0,1,2  3   >  < 0,1,2,3    > <\ 0 \ | \ 3 \ | \ 1 \ | \ 2 \ > \ \rightarrow \ <\ 0 \ | \ 1 \ | \ 2, 3 \ | \ > \ \rightarrow \ <\ 0, 1 \ | \ 2 \ | \ 3 \ | \ > \ \rightarrow \ <\ 0, 1, 2 \ | \ 3 \ | \ | \ > \ \rightarrow \ <\ 0, 1, 2, 3 \ | \ | \ | \ >

در مثال بالا جایگاه‌ها با | جدا شده‌اند و هر صوفی معلوم شده است که در کدام جایگاه قرار دارد.

زیبایی یک نمایش از نظر مردم، تعداد مراحل آن است. مثلا زیبایی نمایش بالا، 44 است. اکنون در آستانه اجرای نمایش، جایگاه تعدادی از صوفی‌ها معلوم شده است ولی بقیه صوفی‌ها هنوز جایگاه ابتدایی‌شان را مشخص نکرده‌اند. فرض کنید تعداد صوفی‌هایی که جایگاه اولیه‌شان مشخص نیست kk باشد. برنامه‌ای بنویسید که مجموع زیبایی همه نمایش‌های ممکن را محاسبه کند،‌ یعنی مجموع زیبایی نمایش‌ها به ازای همه حالاتی که می‌توان صوفی‌هایی که جایگاه‌ ابتدایی‌شان مشخص نیست را در جایگاه‌های خالی قرار داد. ( k!k! حالت ممکن) از آن‌جایی که این عدد ممکن است بزرگ باشد، باقی‌مانده آن را در پیمانه 109+710^{9} + 7 بیابید.

ورودی

سطر اول ورودی شامل دو عدد n,kn, k که nn تعداد صوفی‌ها و kk تعداد صوفی‌هایی که جایگاه ابتدایی‌شان معلوم نیست را مشخص می‌کند.
در خط دوم nn عدد a1,a2,...,ana_1, a_2, ..., a_n می‌آید که aia_i شماره صوفی است که در جایگاه ii قرار دارد.
اگر ai=1a_i = -1 باشد یعنی این مکان، معین نشده است که جایگاه کدام صوفی است.

  • برای هر ii و jj متمایز که ai,aj1a_i,a_j \neq -1 می‌دانیم aiaja_i \neq a_j
  • تعداد ii هایی که ai=1a_i = -1 برابر با kk است.
  • 1n1051 \le n \le 10^{5}
  • 0kmin(n,100)0 \le k \le min(n, 100)
  • ai=1a_i = -1 یا 1ain1 \le a_i \le n

خروجی

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

زیر مسئله ها

زیرمسئله نمره محدودیت ها
۱ ۸ n1000n \le 1000 , k=0k = 0
۲ ۳۱ k=0k = 0
۳ ۲۳ k=nk = n
۴ ۳۸ بدون محدودیت اضافی

مثال

ورودی نمونه ۱

3 0
3 1 2
Plain text

خروجی نمونه ۱

4
Plain text

ورودی نمونه ۲

3 2
3 -1 -1
Plain text

خروجی نمونه ۲

9
Plain text

ارسال پاسخ برای این سؤال
فایلی انتخاب نشده است.