Processing math: 100%

المپدیا

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

ابزار کاربر

ابزار سایت


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

زیگزاگ(ZigZag)

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

محمد توانسته داده‌های n روز اخیر سفارت را به دست آورد. در این داده‌ها، به ترتیب برای روز iام، تعداد وقت‌های ملاقات که باز شده‌اند، آمده است. توجه کنید که این اعداد می‌توانند منفی باشند که به این معنا است که سفارت در آن روز تعدادی وقت ملاقات را کنسل کرده است. حال محمد متوجه شده است که بی‌برنامگی یک سفارت رابطه مستقیم با تعداد زیررشته‌های زیگزاگی از وقت‌های باز شده توسط سفارت دارد.

محمد متوجه شد که داده‌های سفارت از ابتدا درست نیستند و تغییراتی در آن‌ها به وجود می‌آید. همچنین برای او نیز در هنگام اعمال تغییرات سوال‌هایی در رابطه با تحلیل بی‌نظمی سفارت ایجاد می‌شود. در مجموع q تغییر و پرسش برای داده‌های او رخ می‌دهد که یکی از سه حالت زیر هستند:

  • عدد x به اعداد روزهای l تا r اضافه شود.
  • عدد 1 در اعداد روزهای l تا r ضرب شود.
  • تعداد زیررشته‌های زیگزاگی روز‌های l تا r چندتا است.

دقت کنید که تمام تغییرات و سوالات شامل دو سر بازه خود می‌شوند، درواقع خود l و r نیز داخل بازه هستند. حال به محمد کمک کنید که پاسخ سوال‌هایش را پیدا کند تا زودتر بتواند مهاجرت کند و به آرزوهایش برسد و شما برای همیشه از سوال‌های او راحت شوید.

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

یک دنباله مثل b1,b2,b3,,bk زیگزاگی است اگر و تنها اگر یکی از دو شرط زیر را داشته باشد:

  • b1<b2>b3<b4>
  • b1>b2<b3>b4<

ورودی

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

در خط دوم ورودی a1,a2,,an، که برابر با تعداد وقت‌های ملاقات باز شده توسط سفارت در هر روز است.

در خط iام از هر یک از q خط بعدی، ابتدا ti{+,,?} آمده است که + به معنای عملیات نوع اول بر روی داده‌ها است، نشان دهنده عملیات نوع دوم و ? نشان دهنده سوالی است که برای محمد پیش می‌آید. سپس دو عدد li و ri (1lirin) آمده است که نشان‌ دهنده بازه‌ی مورد نظر است. اگر عملیات از نوع اول باشد، یک عدد (109xi109) نیز در ادامه خط آمده است که نشان دهنده عددی است که باید بازه را با آن جمع کرد. دقت کنید که اندیس عضو اول آرایه یک است.

خروجی

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

زیرمسئله‌ها

  • زیرمسئله اول (۸ نمره): n,q5000
  • زیرمسئله دوم (۴۲ نمره):

به ازای تمام خط‌هایی که ti=? داریم: li=1 و ri=n

  • زیرمسئله سوم (۳۵ نمره):n,q105
  • زیرمسئله چهارم (۱۵ نمره): بدون محدودیت اضافی

محدودیت‌ها

  • محدودیت زمان: ۳ ثانیه
  • محدودیت حافظه: ۲۵۶ مگابایت
  • 1n105
  • \item 1n3×105
  • \item 1q3×105
  • \item 109ai109
  • \item 109xi109
  • \item 1lirin

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

ورودی نمونه خروجی نمونه
4 4
2 3 -1 -1
? 1 4
+ 3 3 4
* 1 3
? 2 4
7
4
6 8
-2 7 3 4 1 6
? 1 6
+ 3 5 4
* 1 6
+ 5 6 -3
? 2 5
* 3 5
+ 4 4 -2
? 3 6
21
5
10

ابزار صفحه