
<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>شناخت &#187; حل مسئله</title>
	<atom:link href="http://shenaxt.com/tag/%d8%ad%d9%84-%d9%85%d8%b3%d8%a6%d9%84%d9%87/feed" rel="self" type="application/rss+xml" />
	<link>http://shenaxt.com</link>
	<description>یک سایت دیگر با وردپرس</description>
	<lastBuildDate>Mon, 26 Sep 2011 21:58:01 +0000</lastBuildDate>
	<language>fa</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.0.1</generator>
		<item>
		<title>روشی برای حل مسئله‌ها</title>
		<link>http://shenaxt.com/article/30</link>
		<comments>http://shenaxt.com/article/30#comments</comments>
		<pubDate>Tue, 13 Apr 2010 20:42:38 +0000</pubDate>
		<dc:creator>سهیل خسروی‌پور</dc:creator>
				<category><![CDATA[جستار]]></category>
		<category><![CDATA[حل مسئله]]></category>
		<category><![CDATA[درستی‌سنجی رسمی نرم‌افزار]]></category>

		<guid isPermaLink="false">http://shenaxt.ir/%d8%af%d8%b3%d8%aa%d9%87%e2%80%8c%d8%a8%d9%86%d8%af%db%8c%e2%80%8c%d9%86%d8%b4%d8%af%d9%87/30</guid>
		<description><![CDATA[یکی از روشهای معمول درستی‌سنجی در مبحث درستی‌سنجی رسمی نرم‌افزار [Formal Verification of Software] توجه به شرط‌هایی است که می‌بایست پیش، پس و هنگام اجرای تک تک اجزای برنامه و به طور کلی پیش، پس و هنگام اجرای خود برنامه نامتغیر [Invariable] باشند. بدین شکل که پس از هر مرحله نامتغیر ماندن آن‌ها را بررسی [...]]]></description>
			<content:encoded><![CDATA[<p>یکی از روشهای معمول درستی‌سنجی در مبحث درستی‌سنجی رسمی نرم‌افزار [Formal Verification of Software] توجه به شرط‌هایی است که می‌بایست پیش، پس و هنگام اجرای تک تک اجزای برنامه و به طور کلی پیش، پس و هنگام اجرای خود برنامه نامتغیر [Invariable] باشند. بدین شکل که پس از هر مرحله نامتغیر ماندن آن‌ها را بررسی می‌کنند. در برخی از موارد یافتن اینکه چه شرطی باید نامتغیر باشد خود نیاز به ریزبینی بالایی دارد[۱].</p>
<p>جالب است که علاوه بر درستی‌سنجی رسمی نرم‌افزار در حل برخی مسئله‌ها نیز می‌توان با توجه به نامتغیرها پاسخ مسئله را یافت. برای نمونه دو مسئله ساده را بیان می‌کنم. البته نخست مسئله‌ها را خواهم نوشت و سپس پاسخ‌ها را پایینتر خواهم آورد تا فرصت اندیشیدن را از شما نگیرم.</p>
<p>مثال نخست: در ظرفی گلوله‌هایی به رنگ‌های سفید و سرخ داریم. در هر مرحله دو گلوله از ظرف برمی‌داریم.  اگر گلوله‌های برداشته‌شده همرنگ باشند یک گلوله سرخ در ظرف می‌اندازیم. اما اگر گلوله‌های برداشته‌شده هم‌رنگ نباشند یک گلوله سفید در ظرف می‌اندازیم.</p>
<p>پرسش این است که اگر در آغاز ۳۵۵ گلوله سفید و ۲۱۷ گلوله سرخ وجود داشته باشند، با تکرار مراحل بالا، در پایان کدام رنگ در ظرف باقی خواهد ماند؟</p>
<p>مثال دوم: دو لیوان داریم که در اولی شراب قرمز و در دومی به همان میزان شراب سفید ریخته‌ایم. ابتدا یک قاشق شراب قرمز از لیوان اول به لیوان دوم می‌ریزیم و سپس یک قاشق از لیوان دوم به لیوان اول می‌ریزیم.</p>
<p>پرسش این است که پس از انجام این دو مرحله، مایع موجود در کدام لیوان ناخالصتر است؟</p>
<p>پاسخ‌ها:<br />
همانطور که گفتم می‌خواهیم با توجه به نامتغیرها، مسئله‌ها را حل کنیم.</p>
<p>پاسخ مثال نخست: گلوله سفید در ظرف باقی می‌ماند.<br />
با اندکی دقت واضح است که گلوله‌های سفید دو تا دو تا و گلوله‌های سرخ یکی یکی  کم می‌شوند. آنچه می‌تواند ما را در حل مسئله کمک کند ثابت بودن «دو تا دو تا کم شدن تعداد گلول‌های سفید» است. با توجه به اینکه تعداد گلوله‌های سفید در ابتدا فرد است و آنها دو تا دو تا کم خواهند شد در پایان حتما یک گلوله سفید در ظرف خواهد ماند که نمی‌توانیم آن را برداریم.</p>
<p>اگر تعداد گلوله‌های سفید ۸۷۶ تا بود چه!؟</p>
<p>پاسخ مثال دوم: میزان ناخالصی هر دو یکسان است.<br />
شاید بهتر باشد یافتن استدلالی که به پاسخ این مسأله می‌انجامد را نیز به شما بسپارم. تنها یک راهنمایی کوچک: چه چیزی در مسئله نامتغیر است؟ به حجم لیوان‌ها و قاشق فکر کنید…</p>
<p><strong>پانویس:</strong></p>
<p dir="ltr">[۱] David Gries: The Science of Programming, Springer 1981</p>
]]></content:encoded>
			<wfw:commentRss>http://shenaxt.com/article/30/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
