Processing math: 100%

المپدیا

دانش‌نامه‌ی المپیاد کامپیوتر ایران

ابزار کاربر

ابزار سایت


سوالات المپیاد:دوره ی تابستان:دوره ی ۳۰:عملی نهایی اول:سوال ۲

بزرگ‌ترین زیر دنباله‌ی صعودی(LIS)

مهرشاد یک میوه فروشی دارد که فقط پرتقال می‌فروشد. او پرتقال ها را در q کیسه داخل انبار نگه‌داری می‌کند؛ این کیسه‌ها با اعداد 1 تا q شماره‌گذاری شده‌اند. درون کیسه‌ی iام، xi پرتقال وجود دارد.

او امروز تصمیم گرفته که همه‌ی کیسه‌ها را جلوی مغازه داخل یک ردیف بچیند. برای این کار، در مرحله‌ی iام کیسه‌ی iام را برمی‌دارد و پشت piامین کیسه‌ی پرتقال می‌گذارد (اگر pi=i باشد، کیسه‌ی iام جلوی تمامی کیسه‌های موجود در صف قرار می‌گیرد.) ؛ سپس تمام کیسه‌های جلوی آن را یک واحد به جلو هل می‌دهد. به طور مثال اگر p4=2 باشد، پیش از مرحله‌ی ۴ام در صف ۳ کیسه قرار دارد. پس از این مرحله، کیسه‌ی شماره‌ی ۴ بین کیسه‌ی اول و دوم قرار می‌گیرد. همچنین اگر p4=4 باشد، کیسه‌ی شماره‌ی ۴ جلوی تمام کیسه‌ها قرار می‌گیرد.

او این کار را آن قدر تکرار می‌کند تا کیسه های داخل انبار تمام شوند. مهرشاد بعد از هر عملیاتی که انجام می‌دهد، برایش سوال می‌شود که «طول بزرگ‌ترین زیردنباله‌ی اکیداً صعودی(LIS) صف کیسه‌ها چند است؟» امّا از آن جایی که او سخت درگیر کار و کاسبی‌ش است و وقت سر خاراندن هم ندارد، شما باید به سوالاتش پاسخ دهید.

یک دنباله مثل b1,b2,b3,,bi زیردنباله‌ای از صف پرتقال ها است اگر و فقط اگر، بتوان با حذف تعدادی دلخواه از کیسه ها به ردیفی از کیسه‌ها رسید که تعداد پرتقال‌های درونشان به ترتیب برابر با دنباله‌ی b باشد.

ورودی

در خط اول ورودیq، تعداد کیسه‌های درون انبار می‌آید.

در q خط بعدی در هر خط دو عدد pi و xi می‌آید که اولی نشان دهنده‌ی مکانی است که مهرشاد کیسه‌ی iام را می‌گذارد و دومی برابر با تعداد پرتقال های درون آن هست.

خروجی

به ازای هر عملیات مهرشاد، اندازه‌ی بزرگ‌ترین زیردنباله‌ی صعودی صف پرتقال‌ها را چاپ کنید.

زیرمسئله‌ها

  • زیرمسئله اول (۲۰ نمره): q2000
  • زیرمسئله دوم (۸۰ نمره): بدون محدودیت اضافی

محدودیت‌ها

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

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

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

در مثال اول صف پرتقال ها به این ترتیب تغییر می‌کند:

  • 7
  • 7,10
  • 7,11,10
  • 7,8,11,10
  • 7,8,11,10,10
  • 2,7,8,11,10,10

ابزار صفحه