مهتاب تصمیم گرفته کارهای مدرسهاش را انجام دهد و در هکاتون دیوار شرکت کند. تمرین ریاضی مدرسهی او برای مهتاب که برنامهنویس نیست کار چندان سادهای نیست.
در دفتر مشق مهتاب، عدد طبیعی نوشته شده و از او خواستهاند که اعداد فرد کوچکتر از را در دفترش بنویسد و سپس جمع این اعداد را حساب کند.
معلم مهتاب، هیچوقت اعداد نوشته شده را نگاه نمیکند و فقط حاصل جمع نهایی را بررسی میکند. مهتاب از شما کمک میخواهد که این عدد را پیدا کنید.
در تنها سطر ورودی، عدد صحیح و مثبت داده میشود.
در تنها سطر خروجی، یک عدد صحیح برابر عدد نهایی که باید مهتاب بنویسد را چاپ کنید.
جدولی داریم. سطرهای این جدول از بالا به پایین با اعداد ۱ تا و ستونهای این جدول از چپ به راست با اعداد ۱ تا شمارهگذاری شدهاند. هر خانه از این جدول را میتوان با یک زوج مرتب نشان داد که شمارهی سطر و شمارهی ستون جدول را نشان میدهد.
دزدی وارد این جدول شده و از خانهی آن دزدی کرده و قصد دارد به خانه برود تا بتواند از جدول خارج شود. این دزد در یک حرکت میتواند از یک خانه به خانهی بالا، پایین، چپ یا راست (در صورت وجود) برود.
یک سگ نگهبان، در خانهی این جدول، زندگی میکند. این سگ از خانههای با فاصلهی حداکثر از خانهاش محافظت میکند. در اینجا منظور از فاصلهی خانهی تا خانهی یعنی کمترین تعداد حرکتی که دزد نیاز دارد تا از خانهی به خانهی برسد.
میدانیم اگر دزد به خانهای برود که سگ نگهبان از آن محافظت میکند، اسیر میشود.حال به دزد بگویید آیا میتواند راهی از خانهی به خانهی پیدا کند یا نه.
در خط اول ورودی، عدد صحیح آمده که تعداد پرسشها را نشان میدهد.
سپس در خط بعدی، در هر خط به ترتیب پنج عدد صحیح به شما داده میشود.
خروجی شما باید شامل خط باشد. برای هر پرسش اگر دزد میتواند به خانه برود YES
و در غیر این صورت NO
خروجی دهید.
گاتهام خیابانی است با طول بینهایت که از نقطه ۰ شروع میشود. اگر مبدا زمانی ما از ابتدای ثانیه ۱ آغاز شود، میدانیم که جوکر در هر لحظه از شروع تا پایان ثانیه ام، (به مدت ۱ ثانیه) در نقطهای با فاصله از ابتدای خیابان ایستاده است. به طوری که تمام عرض خیابان را اشغال کرده است.
در نقطه ۰ خیابان، بتمن ماشین دارد که قرار است به ترتیب در ابتدای هر ثانیه یکی از آنها از نقطه ۰ خیابان حرکت کند. به این معنا که در ابتدای ثانیه ۱ یکی از ماشینها حرکت میکند، در ابتدای ثانیه ۲ دیگری حرکت میکند و همینطور ادامه مییابد تا جایی که در ابتدای ثانیه ام، آخرین ماشین حرکت میکند. سرعت تمام ماشینها به شما داده شده است. هدف بتمن این است که جوکر حتماً توسط یکی از ماشینها زیر گرفته شود.
در قرن جدید، ماشینها خودشان رانندگی میکنند و ممکن است قبل از رسیدن به جوکر ترمز کنند. بتمن میخواهد طوری ماشینها را ترتیب دهد که احتمال مرگ جوکر بیشترین مقدار ممکن باشد. به عبارت دیگر، بیشترین تعداد ماشینها که در هر بازه زمانی از ابتدای ثانیه ۱ تا انتهای ثانیه ، میتوانند از روی جوکر عبور کنند، باید تعیین شود.
خط اول ورودی عدد طبیعی و مثبت تعداد سناریو ها به شما داده میشود.
در خط اول هر سناریو به ترتیب سه عدد طبیعی و مثبت ، و به شما ورودی داده میشوند.
در خط دوم هر سناریو عدد طبیعی و مثبت ورودی داده میشوند که هر کدام سرعت یکی از ماشینهای بتمن را نشان میدهد.
خروجی خط دارد. برای هر سناریو، در یک خط باید بیشترین تعداد ماشینهایی که ممکن است در قسمتی از حرکتشان از روی جوکر عبور کنند، چاپ شود.
میخواهیم ساختمان طبقهای کنار هم در یک ردیف بسازیم.
ساختمان در یک طبقه زمانی نورگیر است که از سمت چپ یا راست به فضای باز دسترسی داشته باشد. بهعنوان مثال ساختمانهای انتهای چیدمان (یعنی در سمت چپ یا راست)، تمام واحدهای آن نورگیر خواهند بود.
هدف این است که ساختمانها را به ترتیبی بچینیم که تعداد واحدهای نورگیر به حداکثر برسد. تعداد حداکثری واحدهای نورگیر را پیدا کنید.
در خط اول ورودی عدد تعداد ساختمان ها داده می شود.
سپس در خط بعدی به ترتیب تا داده می شود.
در یک خط، حداکثر تعداد واحد های نورگیر را خروجی دهید.
فرض کنید میخواهیم جایگشتهای a
تا z
را از بیشترین به کمترین ارزش مرتب کنیم (اگر دو جایگشت ارزش برابر داشتند، جایگشتی که از نظر ترتیب الفبایی کوچکتر باشد، دارای اولویت بالاتر است).
ارزش یک جایگشت به شکل زیر تعریف میشود:
منظور از ، تعداد تکرار حرف در رشته است.
از آنجایی که تعداد این جایگشتها بسیار زیادند، کافیاست تنها جایگشت اول را در دنباله نزولی مرتبشده جایگشتها خروجی دهید.
در خط اول، عدد صحیح میآید.
سپس در خط بعد ورودی یک آرایه از اعداد صحیح به طول داده میشود که نشاندهنده تعداد تکرارهای هر حرف از الفبا است.
تضمین میشود که ها اعداد متمایز باشند.
در خط خروجی، در هر خط یک جایگشت از حروف a
تا z
با فاصله از هم خروجی دهید که خط ام نشان دهنده جایگشت ام است.
در این سوال، شما سیستمی برای مدیریت آگهیهای مسکن طراحی میکنید. هر آگهی میتواند برای فروش، رهن یا اجاره باشد و دارای ویژگیهایی از جمله عنوان، قیمت، متراژ، نوع ملک (آپارتمان یا حیاط)، وضعیت (فروش، رهن یا اجاره)، و مختصات جغرافیایی (عرض و طول جغرافیایی) خواهد بود. شما باید این ویژگیها را در کوئریهای مختلف مانند افزودن آگهی، جستجو و حذف آگهیها مدیریت کنید.
add_house
فرم کلی این دستور به صورت زیر است:
<title>
عنوان آگهی (منحصربهفرد و اجباری).<type>
نوع ملک (مانند apartment
برای آپارتمان یا yard
برای حیاط و اجباری).<status>
وضعیت ملک (sale
برای فروش، rent
برای رهن یا اجاره و اجباری).<price>
قیمت ملک (عدد صحیح و مثبت به تومان و اجباری).<area>
متراژ ملک (عدد صحیح و مثبت بر حسب متر مربع و اجباری).<latitude>
عرض جغرافیایی ملک (عدد حقیقی و اجباری).<longitude>
طول جغرافیایی ملک (عدد حقیقی و اجباری).[description]
توضیحات اختیاری.اگر عنوان آگهی قبلاً ثبت شده باشد، پیام invalid title
چاپ شود.
در غیر این صورت، پیام house added successfully
چاپ شود.
get_houses
فرم کلی این دستور به صورت زیر است:
این دستور به معنی جستجو برای آگهیهایی با ویژگیهای مشخص است.
<type>
نوع ملک (مانند apartment
یا yard
و اجباری).<status>
وضعیت ملک (sale
یا rent
و اجباری).[min_price]
حداقل قیمت آگهی (عدد صحیح و اختیاری).[max_price]
حداکثر قیمت آگهی (عدد صحیح و اختیاری).[min_area]
حداقل متراژ آگهی (عدد صحیح وختیاری).[max_area]
حداکثر متراژ آگهی (عدد صحیح و اختیاری).<latitude>
عرض جغرافیایی منطقه جستجو (عدد حقیقی و اجباری).<longitude>
طول جغرافیایی منطقه جستجو (عدد حقیقی و اجباری).در این دستور، آگهیها باید بر اساس نزدیکی جغرافیایی به منطقه جستجو مرتب شوند. آگهیهایی که نزدیکتر به مختصات جستجو هستند، اول نمایش داده شوند. برای محاسبه نزدیکی از فرمول فاصله هاروارد () استفاده کنید. سپس نام آگهیهای مرتبشده را به ترتیب در یک خط و با یک فاصله بین آنها چاپ کنید. (نزدیکترین آگهی باید در ابتدای خط چاپ شود.) اگر لیستی که باید چاپ شود خالی است، عبارت no house found!
را چاپ کنید.
remove_house
فرم کلی این دستور به صورت زیر است:
این دستور به معنی حذف آگهی با عنوان <title>
است.
invalid title
چاپ شود.house removed successfully
چاپ شود.در سطر اول عدد صحیح و مثبت داده میشود که تعداد دستورها را مشخص میکند.
در سطر بعدی، هر سطر شامل یک دستور از نوعهای تعریفشده است.
خروجی شامل سطر است که پاسخ مناسب به هر دستور را چاپ میکند.