اولین باره که به کاهو میای؟ راهنمای سایت رو حتما بخون!

ورود ثبت‌نام راهنما درباره‌ی کاهو
پرسش‌ها برچسب‌ها کاربر‌ها سوال بپرسید!

آمار پرسش:

  • پرسیده شده: 2014-05-01 04:32:27 -0500
  • مشاهده شده: 474 بار
  • بروز شده: 2014-05-15 11:33:45 -0500

پرسش‌های مشابه:

بازی رنگی - سوال ۱ - مرحله ۲ - ۱۳۹۳

وزنه‌ها و ماشین جادویی - سوال ۲ - مرحله ۲ - ۱۳۹۳

گاوی خسیس - سوال ۳ - مرحله ۲ - ۱۳۹۳

سوال ۱ روز دوم مرحله ۲ دوره ۲۳: رشته‌ی نزدیک

یافتن کوچکترین پیچ و مهره با مقایسه آنها

دنباله و جادوگر - دوره ی 24 - مرحله ی 2

دوربین های عکاسی

مسئله ی مسیر و شبکه - مرحله ی 2 – دوره ی 23

بازی خاموش کردن چراغ ها

زمان اعلام نتایج مرحله دوم

نکاتی در مورد نوشتن پاسخ:

در این قسمت می‌تونی به یک پرسش پاسخ بدی. اگه می‌خوای در مورد پرسش بحث و اظهار نظر کنی از قسمت «ثبت نظر» استفاده کن.
پاسخت رو دقیق و کامل بنویس، از عکس استفاده کن و اگه لازمه به منابع (کتاب یا سایت) ارجاع بده.
اگه پرسش یا پاسخ‌ها مفید هستند حتما بهشون رای بده تا پرسش‌ها و پاسخ‌های خوب مشخص بشن.

استفاده از ویرایشگر:

توی قسمت پیش‌نمایش می‌تونی ببینی متنی که نوشتی چجوری روی سایت دیده میشه.
خیلی مهم: برای اینکه به خط بعد بری باید دوتا Enter بزنی.
می‌تونی از تگ‌های معمولی و ساده‌ی html هم استفاده کنی.
با دکمه‌هایی که بالای ویرایش‌گر قرار دارند کلی کار می‌شه کرد. از عکس‌گذاشتن بگیر تا لیست شماره‌دار. حتما امتحان‌شون کن.

علائم ریاضی:

برای نوشتن علائم ریاضی می‌تونی از Mathjax استفاده کنی. راهنمای Mathjax رو از سایت math.stackexchange بخون.
برای نوشتن عبارت ریاضی وسط جمله، اون عبارت رو بین دوتا $ قرار بده.
برای نوشتن عبارت ریاضی تو یه خط جدید اون رو بین دوتا $$ قرار بده.

انتقال مهره‌های گاوی - سوال ۴ - مرحله ۲ - ۱۳۹۳

7

نقاط صحیح صفحه مختصات (نقاطی که طول و عرض آنها عددی صحیح است) را در نظر بگیرید. ببعی $n$ نقطه از این نقاط را به رنگ آبی درآورده است و $n$ مهره نیز در $n$ نقطه‌ی دیگر از صفحه قرار داده است (در هر نقطه یک مهره). می‌دانیم نقاط آبی و مهره‌ها ویژگی‌های زیر را دارند:

  • در هیچ نقطه‌ی آبی، مهره‌ای قرار ندارد.
  • هیچ دو نقطه‌ی آبی در یک سطر نیستند.

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

فرض کنید کمترین تعداد مراحل لازم برای رساندن مهره‌ها به نقاط آبی به طوری که در هر نقطه‌ی آبی یک مهره قرار گیرد، با استفاده از ماشین گاوی $t_1$ و با استفاده از ماشین ببعی $t_2$ باشد. ثابت کنید $t_1=t_2$. (۶۰ نمره)

توجه: شما با اثبات $t_2\leq 2t_1$ نیمی از نمره را می‌توانید بگیرید.

مرحله۲ ۱۳۹۳
2014-05-01 04:32:27 -0500
هادی 271 ● 4 ● 4 ● 10
پاک‌کردن   ویرایش سوال
نظرات

سلام میدونستید انجمن علمی نخبگان دانشگاه صنعتی شریف مسابقه تخصصی مهارت سنجی برنامه نویسی و داده کاوی گذاشته است آدرس سایتش www.fanavard.com

2015-08-06 09:50:25 -0500 امیر شکری

سلام میگم یک سر به سایت www.fanavard.ir بزنید. مسابقات برنامه نویسی شون شروع شده. گواهی رسمی از طرف دانشگاه شریف می ده. 50 تا سکه هم جایزشه

2016-10-27 08:42:02 -0500 امیر شکری

1 پاسخ

4

سلام

پاسخ رسمی کمیته ی المپیاد کامپیوتر:

جواب ماشین گاوی را در نظر بگیرید. چون در ماشین او در یک لحظه می تواند در یک خانه بیش از یک مهره باشد، پس می توان فرض کرد که اگر مهره ای با مختصات $(x_1,y_1)$ را بخواهیم به نقطه ای با مختصات $(x_2,y_2)$ انتقال دهیم، می توانیم ابتدا این مهره را به نقطه ی $(x_1,y_2)$ برده و سپس آن را به خانه ی $(x_2,y_2)$ ببریم. به حرکات موجود در انتقال اول، حرکت عمودی و به حرکات موجود در انتقال دوم حرکت افقی می گوییم. به عبارتی ابتدا مهره را با تعدادی حرکت عمودی به سطر مورد نظر انتقال می دهیم و سپس با تعدادی حرکت افقی به ستون مورد نظر می بریم. همچنین به هر مهره زوج مرتب $(c,d)$ را نسبت دهید که در آن $c$ به معنای تعداد حرکت های عمودی لازم برای این نقطه و $d$ برابر با تعداد حرکت های افقی لازم به ازای این نقطه است.

لم 1

به ازای یک بعد سوال درست است. فرض کنید دو مهره در مسیر حرکت خود با هم برخورد داشته باشند (مثلا مهره های $a$ و $b$ که $a$ می خواهد به خانه ی $A$ برود و $b$ به خانه ی $B$). مقصد این دو مهره را با هم عوض کنید ($a$ به $B$ و $b$ به $A$ برود). با این کار حداقل یک واحد از تعداد برخورد ها کاسته می شود. در ضمن می دانیم با این کار جواب ما از حالت قبلی اش بیش تر نمی شود. این کار را آن قدر تکرار کنید که دیگر برخوردی نداشته باشیم. پس جواب ماشین ببعی و گاوی به ازای یک بعد برابر است.

حل نصف نمره

به ازای مهره ی $i$ام ($1 \le i \le n$)$\;$$e_i$ را برابر $max(c_i,d_i)$ تعریف کنید. حال فرض کنید $F=max_{i=1}^n \; (e_i)$. واضح است که $t_1 \ge F$ است. حال جواب ماشین گاوی را در نظر بگیرید. طبق لم 1، ماشین گاوی می تواند به ما جوابی بدهد که هیچ برخوردی بین دو مهره که در حال انجام حرکات عمودی خود هستند رخ ندهد. حال هر مهره ای، حرکت عمودی خود را انجام و صبر کند تا تمامی مهره ها حرکت های عمودی خود را انجام دهند. سپس هر مهره ای حرکت افقی خود را انجام دهد. اکنون هر کس به خانه ی مورد نظر خود رسیده است. حال خواهیم داشت

$$t_2 \le max(c_i)+max(d_i) \le F+F \le t2_1$$

حل کامل

از بین جواب های موجود برای ماشین گاوی جوابی را در نظر بگیرد که $\sum _{i=1}^n\ c_i^2$ در آن کمینه شود. می خواهیم ثابت کنیم که اگر همچین جوابی را در نظر بگیریم، در هیچ لحظه ای دو مهره در یک خانه نخواهند بود. فرض کنید دو مهره در یک ستون باشند و هنگامی که حرکت عمودی انحام می دهند به یک نقطه برسند. فرض کنید مهره ی $a$ بخواهد به نقطه ی $A$ انتقال باید و مهره ی $b$ نیز به خانه ی $B$ انتقال یابد. حال مهره ی $a$ را به نقطه ی $B$ انتقال دهید و مهره ی $b$ را به خانه ی $A$. $c_a$ و $c_b$ هر دو کم تر شده است چون هیچ دو نقطه ی آبی در یک سطر نیستند. پس مجموع مورد نظر ما کم تر شده است. حال فرض کنید دو مهره از دو ستون مختلف به هم برخورد کنند. در این صورت یکی از آن ها در حال انجام حرکت عمودی خود بوده است و دیگری در حال انجام حرکت افقی خودف زیرا اولا هیچ دو نقطه ی آبی ای در سطر یکسانی نیستند، ثانیا این دو مهره در یک ستون نبودند و قرار بود هر مهره ای که می خواهد به مقصد خود برود، اول حرکات عمودی اش را انجام دهد، سپس حرکات افقی اش را. اکنون مقصد این دو مهره را با هم عوض کنید. از آن جایی که این دو مهره در یک زمان در یک نقطه بوده اند و همچنین یکی از آن ها در حال حرکت افقی بوده و دیگری در حال حرکت عمودی، پس جواب ما بیشتر نشده است. همچنین اثبات می کنیم که مجموع مورد نظر ما منتر شده است اگر جهت حرکت های این دو مهرا با هم متفاوت باشد که از $c$ هر دوی آن ها کاسته شده است پس مجموع نیز کم تر شده است (دقت کنید نقطه های نهایی در یک سطر نیستند.). حال اگر جهت حرکت این دو مهره یکسان باشد، بدون این که از کلیت سوال کاسته شود فرض کنید که جهت حرکت هر دوی آن ها به بالا بوده باشد. حال این مهره ها را با 1 و 2 نشان دهید. همچنین فرض کنید:

$$c_1 \lt c_2 \Rightarrow y_1 \gt y_2$$

$$p=c_2+y_2-(c_1+y_1)$$

حال قرار است مهره 1، $c_1+p$ حرکت عمودی انجام دهد و مهره 2، $c_2-p$ حرکت عمودی انجام دهد.

مجموع ما به اندازه ی $2p(c_1+p-c_2)$ است و مجموع ما کمتر شده است. پس اگر مجموع ما کمینه شود، ماشین به ما جوابی را می دهد که در هیچ لحظه ای دو مهره در یک نقطه نباشد که این همان خواسته ی ماشین ببعی است.

2014-05-15 11:25:37 -0500
المپیادی 984 ● 11 ● 16 ● 27
پاک‌کردن   ویرایش پاسخ

پاسخ شما

فقط در صورتی که پاسخی برای این پرسش دارید، آن را اینجا بنویسید و برای بحث کردن از قسمت «ثبت‌ نظر» استفاده کنید. شما می‌توانید قبل از وارد شدن به سایت پاسخ خود را بنویسید. این پاسخ ذخیره می‌شود و زمانی که شما وارد سایت شدید یا ثبت‌نام کردید منتشر می‌شود.

پیش‌نمایش:

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