به شما عدد صحیح و مثبت داده میشود. از شما میخواهیم یک جدول مانند نمونهها با کاراکترهای .
و D
بکشید به طوری که لوگو را نشان دهد.
در تنها سطر ورودی، عدد صحیح و مثبت داده میشود.
در سطر، کاراکتر را بدون فاصله، درست مطابق نمونهها چاپ کنید.
در یک کافینت کامپیوتر در یک ردیف، کنار هم قرار گرفتهاند. کامپیوترها از تا به ترتیب شمارهگذاری شدهاند.
در ابتدای روز همهی کامپیوترها خالی است. در یک روز گروه به ترتیب در زمانهای مختلف به این کافینت میآیند. هر گروه دو عدد و ارائه میدهد. یعنی این گروه شامل یک جمع نفره است و میخواهند پشت کامپیوتر متوالی با شمارههای بیشتر یا مساوی بنشینند.
حال از شما میخواهیم که این سیستم را مدیریت کنید. یعنی این نفر را پشت کامپیوترهای با شمارههای متوالی و بیشتر یا مساوی قرار دهید. اگر چند بازه برای نشستن این گروه وجود داشت، آنها را روی بازهای با کمترین شماره قرار دهید. اگر انجام چنین کاری ممکن نبود، به آنها «نه» بگویید تا کافینت را ترک کنند.
برای بهتر متوجه شدن خواستهی سوال به نمونهها مراجعه کنید.
در سطر اول ورودی، به ترتیب دو عدد صحیح و مثبت و که با یک فاصله از هم جدا شدهاند، داده میشود.
در سطر بعدی، در هر سطر به ترتیب دو عدد صحیح و که با یک فاصله از هم جدا شدهاند داده میشود.
در سطر، بعد از درخواست، وضعیت مشغول بودن یا نبودن کامپیوترها را بعد از نشستن آن گروه به صورت یک رشته از 0
(خالی) و 1
(پر) چاپ کنید.
به شما عدد صحیح و مثبت داده میشود. از شما میخواهیم بسط دو جملهای را بهصورت نمادین بنویسید.
توجه کنید باید جملات با +
از هم جدا شوند، جملهی باید به ترتیب حاوی ضریب، و باشد. () برای نمایش توان از ^
کنید. اگر مقدار توان حاوی بیش از یک رقم بود، آن را داخل {}
قرار میدهیم. ضرایب و توانهای 1
را نمینویسیم.
برای بهتر متوجه شدن شیوهی نمایش به نمونهها در پایین مراجعه کنید.
در باز شدهی جملات به صورت خواهد بود، ضریب این جمله را با نشان میدهند.
رابطه بازگشتی زیر مقدار آن را بدست میآورد.
در گذشته از مثلث خیام-پاسکال برای پیدا کردن این ضرایب استفاده میکردند. چند سطر اول مثلث خیام به صورت زیر است:
در این مثلث، عدد هر سطر از جمع دو عدد بالای سرش بدست میآید. در واقع میتوان را هم در مثلث خیام نوشت و به همین ترتیب آن را محاسبه کرد.
در تنها سطر ورودی، عدد صحیح و مثبت داده میشود.
در یک سطر، بدون فاصله، باز شدهی عبارت را درست مثل نمونهها چاپ کنید.
در یک شهر نامتناهی خانه وجود دارد. نقشهی این شهر به صورت خطهای موازی با محورهای و صحیح در صفحه است. (مانند شکل) خانههای این شهر روی تقاطعها قرار دارند.
شهرداری با الگویی که در تصویر زیر میبینید از مبدا مختصات شروع کرده و خانهها را پلاک گذاری کرده است.
به شما مختصات یک خانه داده میشود و از شما میخواهیم پلاک آن خانه را پیدا کنید.
در سطر اول ورودی، عدد صحیح و مثبت آمده که تعداد تستها را نشان میدهد.
در تنها سطر هر تست، دو عدد صحیح و که به یک فاصله از هم جدا شدهاند، داده میشود که مختصات یک خانه را نشان میدهد.
برای هر تست، در تنها یک سطر، شمارهی پلاک آن خانه را چاپ کنید.
از شما میخواهیم، قسمتی از سایت برای ارائه فیلمهای سینمایی را طراحی کنیم. قرار است تعدادی فیلم به سایت اضافه شود، هر بازیگر یک پروفایل دارد که به فیلمهایی که در آن بازی کرده را نشان میدهد. هر فیلم هم یک پروفایل دارد که جزئیات آن مثل اسم، سال انتشار، کیفیت فیلم و لیست بازیگران آن را نشان میدهد.
ساختار دستورها به این صورت است که ابتدا بازیگرها و فیلمها روی سایت تعریف میشوند، سپس در دستورهایی به شما گفته میشود که این بازیگر در این فیلم بازی کرده است و شما باید این مورد را ثبت کنید. همچنین ممکن است پروفایل یک بازیگر یا فیلم از سایت حذف شود و شما نباید دیگر آنها را نشان دهید.
فیلمها باید قابلیت دسته بندی شدن داشته بر اساس ویژگیهایشان داشته باشند.
ADD-MOVIE
فرمت کلی دستور به صورت زیر است:
یعنی فیلمی با نام <title>
، محصول سال <date>
با کیفیت <quality>
روی سایت آپلود شده است.
رشتهی <title>
باید حداکثر ۲۰ کاراکتر باشد. رشتهی <date>
باید یک عدد صحیح بین 1888
تا 2024
باشد. رشتهی <quality>
باید یکی از مقادیر 720p
، 1080p
یا 4K
باشد.
بعد از اضافه شدن هر فیلم باید یک عدد نسبت دهید که به آن <movie-id>
میگوییم. برای هر فیلم، این عدد برابر تعداد فیلمهایی است که قبل از این فیلم با دستور ADD-MOVIES
با موفقیت اضافه شدهاند. (مهم نیست اگر بعداً پاک شده باشند.)
یعنی اولین فیلم که بدون خطا اضافه میشود، <movie-id>
آن برابر ۰، دومین فیلم ۱، سومین فیلم ۲ و... خواهد بود.
<title>
قابل قبول نبود، خطای invalid title
را چاپ کنید.<date>
قابل قبول نبود، خطای invalid date
را چاپ کنید.<quality>
قابل قبول نبود، خطای invalid quality
را چاپ کنید.added successfully <movie-id>
را چاپ کنید، که بهجای <movie-id>
مقدار آن را قرار میدهید.REM-MOVIE
فرمت کلی دستور به صورت زیر است:
این دستور یعنی میخواهیم فیلم <movie-id>
از سایت حذف شود.
<movie-id>
اکنون روی سایت وجود ندارد، خطای invalid movie id
را چاپ کنید.removed successfully <movie-id>
را چاپ کنید، که بهجای <movie-id>
مقدار آن را قرار میدهید.ADD-CAST
فرمت کلی دستور به صورت زیر است:
این دستور یعنی میخواهیم بازیگری با نام <name>
را به سایت اضافه کنیم.
رشتهی <name>
باید حداکثر ۲۰ کاراکتر باشد و فقط شامل حروف بزرگ و کوچک انگلیسی باشد.
بعد از اضافه شدن هر بازیگر باید یک عدد نسبت دهید که به آن <cast-id>
میگوییم. مشابه <movie-id>
، برای هر بازیگر، این عدد برابر تعداد بازیگرهایی است که قبل از این بازیگر با این دستور با موفقیت اضافه شدهاند. (مهم نیست اگر بعداً پاک شده باشند.)
<name>
قابل قبول نبود، خطای invalid name
را چاپ کنید.added successfully <cast-id>
را چاپ کنید، که بهجای <cast-id>
مقدار آن را قرار میدهید.REM-CAST
فرمت کلی دستور به صورت زیر است:
این دستور یعنی میخواهیم بازیگری با نام <cast-id>
را از سایت حذف کنیم.
<cast-id>
اکنون روی سایت وجود ندارد، خطای invalid cast id
را چاپ کنید.removed successfully <cast-id>
را چاپ کنید، که بهجای <cast-id>
مقدار آن را قرار میدهید.SHOW-MOVIE
فرمت کلی دستور به صورت زیر است:
در این دستور به شما یک <movie-id>
داده میشود و از شما میخواهیم در فرمت زیر مشخصات این فیلم را چاپ کنید:
که در داخل "
، مقدارهای title
، date
، quality
قرار میگیرد. توجه کنید cast-id
ها باید به ترتیب از کوچک به بزرگ باشند.
اگر فیلمی با این <movie-id>
وجود ندارد. خطای invalid movie id
را چاپ کنید.
SHOW-CAST
فرمت کلی دستور به صورت زیر است:
در این دستور به شما یک <cast-id>
داده میشود و از شما میخواهیم در فرمت زیر مشخصات این بازیگر را چاپ کنید:
که در داخل "
، مقدار name
قرار میگیرد. توجه کنید movie-id
ها باید به ترتیب از کوچک به بزرگ باشند.
اگر بازیگری با این <cast-id>
وجود ندارد. خطای invalid cast id
را چاپ کنید.
LINK-CAST-TO-MOVIE
فرمت کلی دستور به صورت زیر است:
این دستور یعنی بازیگر با شمارهی <cast-id>
در فیلم <movie-id>
حضور داشته و باید این دو را به هم متصل کنید.
<cast-id>
اکنون روی سایت وجود ندارد، خطای invalid cast id
را چاپ کنید.<movie-id>
اکنون روی سایت وجود ندارد، خطای invalid movie id
را چاپ کنید.already linked
را چاپ کنید.successfully linked <cast-id> to <movie-id>
را چاپ کنید، که بهجای <movie-id>
و <cast-id>
مقدار آن را قرار میدهید.FILTER-MOVIES-BY-TITLE
فرمت کلی دستور به صورت زیر است:
در این دستور باید movie-id
تمام فیلمهایی که عنوان آنها با <pattern>
شروع میشود را به ترتیب صعودی که داخل []
قرار دارند و با ,
از هم جدا شدهاند چاپ کنید. (دقیقاً مشابه نمونهها)
FILTER-MOVIES-BY-DATE
فرمت کلی دستور به صورت زیر است:
در این دستور باید movie-id
تمام فیلمهایی که تاریخ انتشار آنها با <date-pattern>
سازگار است را به ترتیب صعودی که داخل []
قرار دارند و با ,
از هم جدا شدهاند چاپ کنید. (دقیقاً مشابه نمونهها)
مقدار <ineq> <n>
یکی از حالتهای>= n
، > n
،= n
، < n
یا <= n
را دارد که بهجای n
یک عدد صحیح قرار میگیرد و شما باید همهی فیلمهایی که data
آنها در سمت چپ این رابطه قرار میگیرد و حاصل درست میشود را چاپ کنید.
FILTER-MOVIES-BY-QUALITY
فرمت کلی دستور به صورت زیر است:
در این دستور باید movie-id
تمام فیلمهایی که کیفیت آن برابر <pattern>
است را به ترتیب صعودی که داخل []
قرار دارند و با ,
از هم جدا شدهاند چاپ کنید. (دقیقاً مشابه نمونهها)
در سطر اول ورودی، عدد صحیح و مثبت آمده که تعداد دستورها را نشان میدهد.
در سطر بعدی، در هر سطر یک دستور مطابق توضیحات سوال داده میشود.
در سطر و در هر سطر، خروجی متناسب با هر دستور را چاپ کنید.