ستارههای گلرنگ رشتههای 0
و 1
را به روش خاص خودشان میسازند و نمایش میدهند.
نمایش 0
به صورت زیر است:
نمایش 1
به صورت زیر است:
حالا، یک رشته از اعداد 0
و 1
به شما داده میشود و میخواهیم نمایش آن را به صورت پشت سر هم به شیوه ستارگان گلرنگ ارائه دهیم.
از شما میخواهیم برای اینکه جزو ستارگان آینده گلرنگ باشید، این چالش را حل کنید.
در سطر اول ورودی، عدد صحیح و مثبت داده میشود که تعداد کاراکترهای رشته را نشان میدهد.
در سطر دوم، یک رشته از 0
و 1
به طول داده میشود.
در سه سطر، رشته داده شده را به روش ستارگان گلرنگ نمایش دهید.
گلابی کوچولو در حمام نشسته و با تیلههای ته شامپوهای تیلهای گلرنگ بازی میکند. در لحظات مختلف، گلی کوچولو وارد حمام میشود و به گلابی کوچولو یک شامپو میدهد که مدت زمان مصرف آن دقیقه است و در دقیقهی تحویل داده میشود.
گلابی میخواهد هرچه سریعتر هر شامپو را تمام کند و به تیلههای آخرش برسد. بنابراین، در شروع هر دقیقه، از بین شامپوهایی که در دسترس دارد، آن را انتخاب میکند که زودتر از بقیه تمام میشود. اگر چند شامپو با این خاصیت وجود داشته باشد، شامپویی را انتخاب میکند که زودتر وارد حموم شده است.
در این مسئله، به شما زمانهای و مدت زمان مصرفهای به ترتیب داده میشود. از شما خواسته شده است که برنامهای بنویسید که در هر لحظه مشخص کند گلابی در حال مصرف کدام شامپو است، اگر او از روشی که گفته شد برای انتخاب شامپوها استفاده کند.
در خط اول ورودی، عدد صحیح و مثبت داده میشود که تعداد شامپوها را نشان میدهد.
در خط بعدی، هر خط شامل دو عدد و است که به ترتیب زمان تحویل و زمان مصرف شامپوی ام را نشان میدهند. تضمین میشود که در تستهای داده شده شرایط زیر برقرار باشد.
در هر لحظه که به گلابی کوچولو شامپو داده میشود، باید مشخص کنید که از بین شامپوهای در دسترس، کدام یک را در حال مصرف است.
در این نمونه، در لحظه ۰ گلابی شامپوی اول را دریافت میکند که ۱۰ دقیقه زمان مصرف دارد. از آنجایی که گلابی در ابتدا تنها این شامپو را دارد، بلافاصله شروع به استفاده از آن میکند. سپس در لحظه ۴ گلابی شامپوی دوم را دریافت میکند که زمان مصرف آن ۷ دقیقه است. با اینکه شامپوی دوم تازه وارد شده است، گلابی همچنان در حال استفاده از شامپوی اول است چون ۶ دقیقه تا پایان آن باقی مانده است. بنابراین، در هر دو لحظه، گلابی همچنان در حال مصرف شامپوی شماره ۱ است.
در این نمونه، در لحظه ۰ گلابی شامپوی اول را دریافت میکند که ۱۰ دقیقه مصرف دارد و شروع به استفاده از آن میکند. در لحظه ۱۰ گلابی شامپوی دوم را دریافت میکند که زمان مصرف آن ۲۰ دقیقه است. از آنجایی که شامپوی اول تا زمان ۱۰ تمام میشود، گلابی از شامپوی دوم استفاده میکند. در لحظه ۳۱، گلابی شامپوی سوم را دریافت میکند که ۴۰ دقیقه زمان مصرف دارد. از آنجایی که شامپوی دوم تا زمان ۳۱ تمام میشود، گلابی از شامپوی سوم استفاده میکند.
در این نمونه، در لحظه ۰ گلابی شامپوی اول را دریافت میکند که ۱۰ دقیقه مصرف دارد و شروع به استفاده از آن میکند. در لحظه ۱ گلابی شامپوی دوم را دریافت میکند که زمان مصرف آن ۹ دقیقه است. از آنجایی که شامپوی اول هم ۹ دقیقهی دیگر تمام میشود، گلابی از شامپوی اول استفاده میکند. در لحظه ۱۹، گلابی شامپوی سوم را دریافت میکند که ۱۰۰ دقیقه زمان مصرف دارد. از آنجایی که شامپوی اول و دوم تا زمان ۱۹ تمام میشود، گلابی از شامپوی سوم استفاده میکند.
در این نمونه، در لحظه ۰ گلابی شامپوی اول را دریافت میکند که ۱۰ دقیقه مصرف دارد و شروع به استفاده از آن میکند. در لحظه ۱ گلابی شامپوی دوم را دریافت میکند که زمان مصرف آن ۹ دقیقه است. از آنجایی که شامپوی اول ۹ دقیقهی دیگر تمام میشود، گلابی از شامپوی اول استفاده میکند. در لحظه ۱۹، گلابی شامپوی سوم را دریافت میکند که ۱۰۰ دقیقه زمان مصرف دارد. از آنجایی که شامپوی اول و دوم تا زمان ۱۹ تمام میشود، در لحظهی ۱۸ گلابی از شامپوی دوم استفاده میکند.
در شهر گلرنگ خیابان افقی یکطرفه شمال به جنوب و خیابان عمودی یکطرفه غرب به شرق وجود دارد. همانطور که انتظار داریم تمام خیابانهای عمودی با یکدیگر و تمام خیابانهای افقی نیز با یکدیگر موازیاند و همچنین هر خیابان افقی با تمام خیابانهای عمودی متقاطع است. تعدادی تپسی داریم که میخواهند این خیابانها را از ابتدا تا انتها طی کنند.
در هر تقاطع یک چراغ راهنمایی وجود دارد که در هر لحظه برای یکی از دو خیابان تقاطع سبز و برای دیگری قرمز است. هر کدام از چراغها یک عدد به نام دارند که با شروع از لحظه صفر برای خیابان افقی آن تقاطع به طور متناوب ثانیه سبز و سپس ثانیه قرمز اند. همچنین هر تقاطع یک عدد نیز دارد که نشان میدهد در در هر ثانیه در آن تقاطع حداکثر تپسی میتوانند عبور کنند.
در ابتدای هر خیابان تعداد مشخصی تپسی وجود دارند که همزمان با شروع از ثانیه ۰ حرکت کرده و میخواهند به انتهای خیابان خودشان برسند. طی کردن طول هر خیابان در شهر گلرنگ انقدر سریع است که میتوان گفت ۰ ثانیه زمان نیاز دارد. اما در این شهر عبور از تقاطعها زمان نیاز دارد. هر تپسی در صورتی میتواند از یک تقاطع عبور کند که چراغ قرمز آن تقاطع برای آن خیابان سبز باشد. دقت کنید در هر تقاطع میزان مشخصی تپسی در هر ثانیه میتواند عبور کند، پس ممکن است تپسیها پشت چراغ قرمز تقاطعی منتظر بمانند و چندین بار سبز شدن چراغ را مشاهده کنند تا در نهایت بتوانند از تقاطع عبور کنند.
شهردار شهر گلرنگ از شما میخواهد آخرین ثانیهای که یک تپسی به انتهای خیابان خود میرسد را بگویید.
در سطر اول ورودی دو عدد و داده میشود که به ترتیب نشاندهنده تعداد خیابانهای افقی و عمودی است. سپس در خط دوم عدد، تعداد تپسیهای خیابانهای افقی و در خط بعدی عدد به عنوان تعداد تپسیهای خیابانهای عمودی داده میشود.
سپس در خط بعدی در هر خط عدد نشانگر اطلاعات چهارراههای خیابانهای افقی است. در هر خط به ترتیب جفت و داده میشود که بیانگر میزان ثانیه سبز برای چراغ در این خیابان است و برابر حداکثر تعداد تپسی ای است که در یک ثانیه از این چهارراه میتواند عبور کند.
در تنها سطر خروجی ثانیهای که در پایان آن، آخرین تپسی به مقصد میرسد را چاپ کنید.
دور یک میز گرد کارمند از شرکت گلرنگ و کارمند از شرکت کوئرا ایستادهاند و میخواهند دور میز شام بنشینند. سرآشپز میخواهد به کارمندان کوئرا کباب کوبیده و به کارمندان گلرنگ جوجه کباب بدهد، بنابراین میخواهد همهی کارمندان کوئرا کنار هم و همهی کارمندان گلرنگ کنار هم بنشینند.
مشکل اینجاست که اکنون همهی این نفر نشستهاند و حالا باید جای خود را تغییر بدهند. برای تغییر جا با توجه به اینکه مبلهای راحتی در نظر گرفته شده، میتوانیم یک کارمند را از دور میز بلند کنیم و در جایی دیگر بین دو کارمند اضافه کنیم. این کار یک واحد انرژی جمع را کم میکند.
سوال اینجاست کمترین میزان انرژی که لازم داریم تا همهی کارمندهای گلرنگ و کوئرا کنار هم باشند چقدر است؟
در سطر اول ورودی، عدد صحیح و مثبت آمده که تعداد تستها را نشان میدهد.
در سطر اول هر تست، دو عدد صحیح و مثبت و داده میشود که تعداد کارمندان گلرنگ و کوئرا را نشان میدهد.
در سطر دوم هر تست، یک رشته به طول از کاراکترهای G
و Q
آمده است که وضعیت نشستن کارمندان را نشان میدهد.
تضمین میشود که مجموع برای همهی تست حداکثر باشد.
برای هر تست، در یک خط به ترتیب کمترین میزان انرژی لازم برای درست کردن ترتیب را چاپ کنید.
برای این سوال هر چقدر ارسال شما بهینهتر باشد، نمرهی بیشتری میگیرید و لزوماً گرفتن نمرهی کامل امکانپذیر نیست. |
---|
روی نقشه شهر گلرنگ مرکز خرید وجود دارد، مرکز خریدها با اعداد ۱ تا شمارهگذاری شدهاند. مرکز شمارهی در نقطهی قرار دارد.
گل آقا عاشق کیک دوقولوی تاینی است. این کیک فقط در مراکز اکلا وجود دارد. میدانیم مرکز ام کیک دارد و از اولین لحظهای که این مقدار تمام شود. روز بعد، مجدداً کیک به این فروشگاه ارسال میشود. هیچ کس جز گل آقا از این کیکها نمیخرد.
حال گل آقا در نقطهی است. سرعت حرکت او است. او اکنون ثانیه وقت دارد که در شهر بچرخد و بیشترین تعداد کیک را بخرد. از شما میخواهیم برنامهای بنویسید که این بیشترین مقدار را حساب کند.
توجه کنید زمان مراجعهها لزوماً اعداد صحیح نیستند، همچنین باید فاصلهی زمان مراجعه کردن به دو فروشگاه قابل رسیدن باشد. فرض میشود که زمان خرید کردن ناچیز بوده و به مجض مراجعه همهی کیکهای موجود خریداری میشود.
همچنین میتوان نزیک یک فروشگاه ایستاد و چندبار از آن خرید کرد اما باید ثانیه از خرید قبلی گذشته باشد.
در سطر اول ورودی، سه عدد صحیح ، و آمده که تعداد فروشگاهها، زمان شارژ شدن کیک و کل زمانی که گل آقا دارد را نشان میدهد.
در سطر بعدی، در هر سطر سه عدد ، و آمده که مختصات و تعداد کیکها را نشان میدهد.
تضمین میشود هیچ دو مرکز اکلا در یک نقطه قرار ندارند.
در سطر اول، دو عدد صحیح چاپ کنید که به ترتیب حداکثر مجموع کیکهایی و تعداد فروشگاههای مراجعه شده را نشان میدهد.
در سطر بعدی، در هر سطر دو عدد و آمده که زمان مراجعه و شمارهی فروشگاه را نشان میدهد.