Processing math: 100%

المپدیا

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

ابزار کاربر

ابزار سایت


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

بریم مصر (Let's go to Egypt)

پس از اینکه روابط ایران و مصر بهبود یافت، سه نفر از ایرانیان توانستند ویزای مصر را اخذ کنند. آنها پس از رسیدن به مصر، قصد دارند که اول از خیابان معروف «طلعت حرب» دیدن کنند. در این خیابان n ساختمان وجود دارد که در یک خط صاف قرار دارند و به ترتیب از چپ به راست از 1 تا n شماره‌گذاری شده‌اند. همجنین زیبایی ساختمان iم برابر ai است.

حال در فرودگاه Q تاکسی موجود است. تاکسی شماره i آن سه نفر را در فرودگاه سوار کرده و مقابل ساختمان li پیاده می‌کند و سپس در مقابل ساختمان ri منتظر می‌ماند تا آن‌ها را سوار کرده و به سمت هتل ببرد. (liri) آنها اگر تاکسی شماره i را انتخاب کنند، پس از پیاده شدن از تاکسی همواره به سمت راست می‌روند تا به ساختمان ri برسند و آنجا سوار تاکسی شوند.

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

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

بازدید از یک ساختمان در صورتی برای آنها خوشایند است که اکثریت آنها (حداقل دو نفر) راضی به بازدید از آن ساختمان باشند.

آنها به ازای هر کدام از تاکسی‌ها می‌خواهند بدانند که به چند طریق می‌توانند تعدادی از ساختمان‌هایی که از رو به روی آنها گذر می‌کنند را انتخاب کنند و از آن‌ها بازدید کنند. توجه کنید که آنها از ساختمان های li و ri نیز می‌توانند بازدید کنند. به عبارت دیگر آنها از ساختمان‌های یک زیر بازه از بازه‌ی [li,ri] بازدید می‌کنند.

همچنین نفر سوم به عنوان پیرترین نفر جمع به شما توصیه می‌کند که برای فهم بهتر سوال به نمونه ورودی ها توجه کنید.

ورودی

در خط اول n یا همان تعداد ساختمان‌ها می‌آید.

در خط دوم n عدد صحیح می‌آیند که عدد iم همان ai است.

در خط سوم Q یا همان تعداد تاکسی‌ها می‌آید.

در Q خط بعدی در هر خط دو عدد li,ri به ترتیب می‌آیند.

خروجی

در تنها خط خروجی Q عدد چاپ کنید که عدد iم تعداد حالت‌های بازدید کردن آن‌ها در صورت استفاده از تاکسی iم است.

زیرمسئله‌ها

  • زیرمسئله اول (۹ نمره): n500.
  • زیرمسئله دوم (۱۶ نمره): n5000.
  • زیرمسئله سوم (۳۶ نمره): n105,Q3000.
  • زیرمسئله چهارم (۳۹ نمره): بدون محدودیت اضافی

محدودیت‌ها

  • 1n5×105
  • 0ai109
  • 1lirin

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

ورودی نمونه خروجی نمونه
5
5 4 1 3 2
5
1 5
2 5
2 4
1 3
1 2
11 9 6 5 3
9
5 2 3 3 6 4 6 4 1
5
1 9
4 9
3 8
2 5
7 8
29 15 18 10 3

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

در ورودی نمونه اول به ازای تاکسی دوم، تعداد کل حالت‌هایی که میتوانند از تعدادی ساختمان متوالی بازدید بکنند برابر ۱۰ است. از بین این ۱۰ حالت، حالتی که از کل ساحتمان‌ های بازه [2,5] بازدید بکنند خوشایند نیست؛ زیرا نفر اول و دوم راضی به بازدید از ساختمان با زیبایی ۳ نیستد.‌

سعی کنید سوالات را با کمترین راهنمایی از بالا به پایین حل کنید.

راهنمایی

شرط لازم و کافی برای قابل بازدید بودن یک بازه، چنین است که طول بلندترین زیردنباله نزولی (نه لزوما اکید) این بازه حداکثر ۲ باشد.

راهنمایی

به ازای هر ساختمان مانند i، کوچکترین l را به دست می‌آوریم که بازه‌ی [l,i] شرط راهنمایی ۱ را داشته باشند. این مقدار را left[i] می نامیم. در این صورت تمام بازه‌های [j,i] به طوری که lir نیز شرط راهنمایی ۱ را دارند.

راهنمایی

جواب مسئله برای پرسش [l,r] برابر با مجموع (ileft[i]+1) به ازای تمام lir است.

راهنمایی

دفت کنید که آرایه‌ی left[i] ها صعودی است.

راهنمایی

با استفاده از الگوریتم‌های جست‌ و جوی دودویی و جمع پیشوندی (prefixsum) می‌توان مقدار گفته شده در راهنمایی ۳ را در O(logn) محاسبه کرد.


ابزار صفحه