Skip to main content
🔬 Advanced ✨ New

ماشین حساب مدولو

باقیمانده یک عمل تقسیم را محاسبه کنید. a mod b را با توضیح گام‌به‌گام پیدا کنید. ابزار ریاضی رایگان با نتایج فوری و دقیق.

عملیات مادول چیست؟

عملیات مادول (mod یا %) باقی‌مانده پس از تقسیم یک عدد بر عدد دیگر را برمی‌گرداند. برای a mod b: a را بر b تقسیم کنید و نتیجه باقی‌مانده است. به عنوان مثال، 17 mod 5 = 2 (چون 17 = 3×5 + 2). نتیجه همیشه در بازه [0, b-1] برای مقادیر مثبت است.

رابطه اساسی: a = q×b + r، جایی که q مقدار باقی‌مانده (floor(a/b)) و r باقی‌مانده (0 ≤ r < b) است. مادول عملیات همراه با تقسیم صحیح است — اگر a ÷ b = q با باقی‌مانده r باشد، آنگاه a mod b = r. این ماشین حساب از تعریف ریاضی واقعی مادول (همیشه غیر-منفی برای مقسوم‌علیه مثبت) استفاده می‌کند، نه باقی‌مانده با علامت که توسط برخی زبان‌های برنامه‌نویسی استفاده می‌شود.

حساب مادولی — حساب با مادول ثابت جایی که اعداد "دور می‌زنند" — پایه حساب ساعت را تشکیل می‌دهد. ساعت‌ها بر روی ساعت با مادول 12 یا مادول 24 محاسبه می‌شوند. اگر ساعت 10 صبح است و 5 ساعت اضافه کنید: (10 + 5) mod 12 = 3 (بعدازظهر). این رفتار دورزنی در مرکز بی‌شمار الگوریتم‌ها در علوم کامپیوتر، رمزنگاری و نظریه اعداد قرار دارد.

مثال‌های مادول و راه حل‌های گام‌به‌گام

درک مادول با مثال‌های کاربردی بدیهی می‌شود. برای هر محاسبه زیر، فرمول این است: باقی‌مانده = a − floor(a ÷ b) × b.

عبارتمقدار باقی‌مانده (floor)باقی‌مانده (a mod b)تایید
17 mod 5323×5 + 2 = 17 ✓
20 mod 4505×4 + 0 = 20 ✓
7 mod 3212×3 + 1 = 7 ✓
100 mod 714214×7 + 2 = 100 ✓
13 mod 13101×13 + 0 = 13 ✓
1 mod 5010×5 + 1 = 1 ✓
256 mod 1616016×16 + 0 = 256 ✓
365 mod 752152×7 + 1 = 365 ✓

توجه کنید 365 mod 7 = 1: این به ما می‌گوید که یک سال غیر-کبیسه 52 هفته کامل به علاوه 1 روز اضافی دارد، به همین دلیل روز هفته در هر سال غیر-کبیسه 1 روز تغییر می‌کند. یک سال کبیسه (366 روز) mod 7 = 2، روز را 2 روز تغییر می‌دهد.

کاربردهای حساب مادولی

مادول در سراسر برنامه‌نویسی و ریاضیات ظاهر می‌شود. چک کردن زوج/فرد: اگر n % 2 == 0، n زوج است. آرایه‌های دایره‌ای و بافرهای حلقه ای: index = (current_index + 1) % array_size به ابتدای دایره برمی‌گردد. جداول هش: bucket = hash(key) % num_buckets هر مقدار هش را به یک شاخص باکت معتبر نگاشت می‌کند، اطمینان حاصل می‌کند که هیچ دسترسی خارج از محدوده وجود ندارد.

در محاسبات تقویم، محاسبات روز هفته از مادول 7 استفاده می‌کند. فرمول زلِر و الگوریتم روز قیامت هر دو به حساب مادولی برای تعیین روز هفته برای هر تاریخ اعتماد دارند. این‌ها کار می‌کنند زیرا دقیقاً 7 روز در یک هفته وجود دارد — یک مادول ثابت. اختلافات منطقه زمانی از مادول 24 برای بستن صحیح مقدار ساعت‌ها در سراسر مرزهای نیمه‌شب استفاده می‌کنند.

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

در تشخیص خطا، چک‌های اضافی چرخه‌ای (CRCs) و چک‌سام‌ها با استفاده از حساب مادولی چندجمله‌ای بر GF(2) محاسبه می‌شوند. شماره‌های کارت اعتباری از الگوریتم لوهن (یک چک مادول-10) عبور می‌کنند. شماره‌های کتاب ISBN-10 از مادول 11 استفاده می‌کنند. این چک‌سام‌ها خطاهای جابجایی و تک رقمی در کدهای عددی را شناسایی می‌کنند.

مادول در رمزنگاری

حساب مادولی پایه ریاضی رمزنگاری کلید عمومی مدرن است. سه الگوریتم رمزنگاری مهم‌ترین — RSA، Diffie-Hellman و رمزنگاری خم بیضوی — همگی به عملیات‌هایی که مادول یک عدد اول بزرگ یا عدد مرکب انجام می‌شوند اعتماد دارند.

رمزگذاری RSA از توان‌گیری مادولی استفاده می‌کند: برای رمزگذاری یک پیام M با کلید عمومی (e, n)، C = M^e mod n را محاسبه کنید. برای رمزگشایی، M = C^d mod n را محاسبه کنید که d کلید خصوصی است. امنیت بر سختی تجزیه n (یک عدد نیمه اول بزرگ) تکیه دارد — تنها با دانستن n، بازیابی p و q برای اندازه‌های کلید بالاتر از 2048 بیت از لحاظ محاسباتی غیرممکن است.

تبادل کلید Diffie-Hellman به دو طرف اجازه می‌دهد تا یک راز مشترک را بر روی یک کانال ناامن ایجاد کنند: آلیس A = g^a mod p را می‌فرستد، باب B = g^b mod p را می‌فرستد. هر طرف راز مشترک را محاسبه می‌کند: آلیس B^a mod p = g^(ab) mod p را محاسبه می‌کند، باب A^b mod p = g^(ab) mod p را محاسبه می‌کند. یک شنودگری که g^a mod p و g^b mod p را رهگیری کند نمی‌تواند g^(ab) mod p را بدون حل مسئله لاگاریتم گسسته بازیابی کند.

امنیت این سیستم‌ها به ماهیت یک‌طرفه توان‌گیری مادولی بستگی دارد: محاسبه g^a mod p سریع است (با استفاده از تکرار مربع، O(log a) ضرب‌ها)، اما معکوس کردن آن — یافتن یک g^a mod p داده شده — باور می‌رود برای اعداد اول بزرگ p زمان افزایشی لازم دارد.

مدول با اعداد منفی و موارد خاص

رفتار مدول با اعداد منفی در زبان‌های برنامه‌نویسی متفاوت است، که باعث بروز بسیاری از اشکالات دشوار پیدا می‌شود. درک این تفاوت برای توسعه دهندگان نرم‌افزار حیاتی است.

زبان-7 % 37 % -3تعریف
Python2-2نشان دنبال کننده مقسوم‌علیه (مدول واقعی)
JavaScript-11نشان دنبال کننده مقسوم (باقی‌مانده)
C / C++-11نشان دنبال کننده مقسوم (C99+)
Java-11نشان دنبال کننده مقسوم
Ruby2-2نشان دنبال کننده مقسوم‌علیه (مدول واقعی)
ریاضی (تعریف)21 (یا تعریف نشده)همیشه غیر منفی برای مقسوم‌علیه مثبت

در ریاضیات، مدول همیشه یک نتیجه غیر منفی برمی‌گرداند: -7 mod 3 = 2 (از آنجایی که -7 = -3×3 + 2، و 0 ≤ 2 < 3). این ماشین حساب از تعریف ریاضی استفاده می‌کند.

راه امن برای تضمین یک نتیجه غیر منفی در هر زبانی: ((a % b) + b) % b. این ورودی‌های منفی را به درستی کنترل می‌کند و توسط ماشین حساب ما به طور داخلی استفاده می‌شود. این الگو زمانی ضروری است که از مدول برای فهرست‌بندی آرایه یا محاسبات روز تقویم استفاده می‌کنید که در آن نتایج منفی باعث خطا می‌شوند.

موارد خاصی که باید به یاد داشت: (1) هر عدد mod 1 = 0 — تقسیم بر 1 باقی‌مانده ای باقی نمی‌گذارد. (2) هر عدد mod خودش = 0. (3) 0 mod هر عدد غیر صفر = 0. (4) تقسیم (و مدول) بر صفر تعریف نشده است — همیشه مقسوم‌علیه را قبل از محاسبه مدول تأیید کنید. ماشین حساب ما پیام خطای واضحی برای مدول بر صفر نمایش می‌دهد.

مدول و تست‌های قابلیت تقسیم

یکی از کاربردهای عملی مدول، تست قابلیت تقسیم بدون انجام تقسیم کامل است. یک عدد a توسط b قابل تقسیم است اگر و تنها اگر a mod b = 0. این امکان چک‌های سریع قابلیت تقسیم را فراهم می‌کند:

قابلیت تقسیم برتستمثال
2n mod 2 = 0 (رقم آخر زوج)128 mod 2 = 0 ✓
3مجموع رقم‌ها mod 3 = 0123: 1+2+3=6, 6 mod 3 = 0 ✓
4دو رقم آخر mod 4 = 0312: 12 mod 4 = 0 ✓
5رقم آخر 0 یا 5 است735 mod 5 = 0 ✓
9مجموع رقم‌ها mod 9 = 0369: 3+6+9=18, 18 mod 9 = 0 ✓
10n mod 10 = 0 (رقم آخر 0 است)500 mod 10 = 0 ✓

این قوانین قابلیت تقسیم مختصراتی هستند که از خواص حساب مدولی گرفته شده‌اند. قوانین مجموع رقم‌ها برای 3 و 9 کار می‌کنند زیرا 10 ≡ 1 (mod 3) و 10 ≡ 1 (mod 9)، به این معنی که مقدار مکانی هر رقم برای قابلیت تقسیم توسط 3 یا 9 بی ربط است. این‌ها در مدرسه ابتدایی بدون زمینه حساب مدولی تدریس می‌شوند، اما مکانیسم اساسی آن مدول است.

توان مدولی: توان سریع مدول

محاسبه مستقیم a^b mod n با محاسبه اولیه a^b، سپس گرفتن mod n، برای توان‌های بزرگ غیرعملی است — a^100 می‌تواند هزاران رقم داشته باشد. توان مدولی از همانی (a×b) mod n = ((a mod n) × (b mod n)) mod n برای نگه داشتن نتایج میانی کوچک استفاده می‌کند.

الگوریتم سریع از تکرار مربع‌گیری (توان دهی دودویی) استفاده می‌کند:

این تعداد ضرب‌ها را از b به O(log₂ b) کاهش می‌دهد. برای b = توان‌های RSA 2048-بیتی (حدود 10^600)، این تفاوت بین تریلیون‌ها ضرب و فقط ~2000 است. بدون این بهینه‌سازی، رمزگذاری RSA کاملاً غیرعملی خواهد بود.

سوالات متداول

15 mod 4 چقدر است؟

15 mod 4 = 3. چون 15 = 3×4 + 3، باقی‌مانده 3 است. تأیید کنید: 3×4 = 12، و 15 − 12 = 3. ✓

mod 0 چه معنایی دارد؟

مدول بر حسب صفر تعریف‌نشده است، مانند تقسیم بر صفر. نمی‌توانید a mod 0 را محاسبه کنید. ماشین‌حساب ما در این حالت پیام خطا نمایش می‌دهد. هر عملیاتی که بر اساس تقسیم است، نیازمند یک مقسوم‌علیه غیر صفر دارد.

مدول چگونه به پذیرش تقسیم مربوط می‌شود؟

یک عدد a توسط b پذیرفته می‌شود اگر و تنها اگر a mod b = 0. به عنوان مثال، 24 mod 6 = 0، بنابراین 24 توسط 6 پذیرفته می‌شود. 25 mod 6 = 1، بنابراین 25 توسط 6 پذیرفته نمی‌شود. این ویژگی مدول را به ابزار اساسی برای آزمون پذیرش تقسیم در علوم کامپیوتر تبدیل می‌کند.

تفاوت بین مدول و باقی‌مانده چیست؟

برای اعداد مثبت، مدول و باقی‌مانده یکسان هستند. برای اعداد منفی، آن‌ها متفاوت هستند: مدول ریاضی همیشه یک نتیجه غیر منفی برمی‌گرداند (علامت دنبال‌کننده مقسوم‌علیه است)، در حالی‌که باقی‌مانده علامت تقسیم‌شونده را می‌گیرد. به عنوان مثال، -7 mod 3 = 2 (ریاضی)، اما -7 باقی‌مانده 3 = -1 (مانند C، Java، JavaScript).

10 mod 3 چقدر است؟

10 mod 3 = 1. چون 10 = 3×3 + 1، باقی‌مانده 1 است. می‌توانید تأیید کنید: 3×3 = 9، و 10 − 9 = 1. این بدان معنی است که 10 هنگام تقسیم بر 3 باقی‌مانده 1 دارد، بنابراین 10 توسط 3 پذیرفته نمی‌شود.

0 mod 5 چقدر است؟

0 mod 5 = 0. صفر تقسیم بر هر عدد غیر صفر باقی‌مانده 0 و ناتایج 0 را می‌دهد. به طور کلی، 0 mod n = 0 برای هر n ≠ 0. این با تعریف سازگار است: 0 = 0×5 + 0.

مدول در برنامه‌نویسی چگونه استفاده می‌شود؟

استفاده‌های رایج در برنامه‌نویسی عبارتند از: بررسی زوج/فرد (n%2==0)، پیچیدگی شاخص‌های آرایه (index%length)، پیاده‌سازی بافرهای حلقوی، توزیع موارد به سطل‌ها در جداول هش (hash%size)، چرخش در حالت‌های یک ماشین حالت، و اطمینان از اینکه رویدادهای دوره‌ای در هر nامین تکرار اجرا شوند (counter%n==0).

حساب مدولی ساعت چیست؟

حساب مدولی ساعت حساب مدولی روزمره است. یک ساعت 12 ساعته از mod 12 استفاده می‌کند: 11 ساعت + 3 ساعت = (11+3) mod 12 = 2 ساعت. این رفتار پیچیدگی دقیقاً حساب مدولی است. به طور مشابه، روزهای هفته از mod 7 استفاده می‌کنند، و زمان نظامی از mod 24 برای ساعت‌ها استفاده می‌کند.

چرا مدول در رمزنگاری مهم است؟

حساب مدولی امکان استفاده از توابع یک‌طرفه را فراهم می‌کند. محاسبه g^a mod p (با توجه به g، a، p) سریع است، اما یافتن یک g^a mod p و p (مشکل لگاریتم گسسته) برای اعداد اول بزرگ از نظر محاسباتی غیر امکان‌پذیر است. این نامتقارن پایه مبادله کلید Diffie-Hellman، RSA، و بیشتر رمزنگاری کلید عمومی که ارتباطات اینترنتی را محافظت می‌کند، است.

نتیجه هر عدد mod 1 چقدر است؟

هر عدد صحیح mod 1 = 0. تقسیم بر 1 همیشه باقی‌مانده ایجاد نمی‌کند — هر عدد صحیح به طور کامل توسط 1 پذیرفته می‌شود. این از نظر ریاضی سازگار است: a = a×1 + 0، بنابراین باقی‌مانده همیشه 0 است. این مورد خاص در پیاده‌سازی‌های حساب مدولی مهم است.

مدول در زندگی روزمره: مثال‌های عملی

حساب مدولی بسیار بیشتر از آنچه که بیشتر افراد معتقدند در زندگی روزمره ظاهر می‌شود. لحظه‌ای که ساعت را می‌خوانید، محاسبه می‌کنید که یک رویداد هفتگی چه زمانی تکرار می‌شود، بررسی می‌کنید که آیا یک عدد قابل تقسیم بر 9 است یا خیر، یا به رقم آخر یک سال نگاه می‌کنید تا مشخص کنید که سالگرد در چه روزی از هفته رخ می‌دهد، شما در حال انجام حساب مدولی هستید — حتی اگر از این نام برای آن استفاده نکنید.

برنامه‌ریزی و تکرار: اگر یک رویداد هر 7 روز رخ دهد و امروز سه شنبه (روز 2، از یکشنبه=0 شروع می‌شود) باشد، پس 30 روز از حالا (2+30) mod 7 = 32 mod 7 = 4 است، که پنج شنبه است. این محاسبه مستقیم سریع‌تر از شمارش هفته‌ها و روزها به صورت جداگانه است. به همین ترتیب، اگر یک اشتراک در 28 هر ماه تمدید شود و در حال حاضر 15 است، روزهای تا تمدید (28−15) mod 31 = 13 روز است.

ارقام کنترل دیجیتال: استاندارد بارکد ISBN-13 از مدول 10 استفاده می‌کند. رقم آخر هر ISBN-13 به گونه‌ای انتخاب می‌شود که مجموع وزنی تمام 13 رقم قابل تقسیم بر 10 باشد. اگر هنگام وارد کردن ISBN یک کتاب یک رقم را اشتباه تایپ کنید، کنترل شکست می‌خورد (mod 10 ≠ 0) و یک خطا علامت‌گذاری می‌شود. شماره‌های کارت اعتباری از الگوریتم Luhn — یک چک مدول 10 — برای همین هدف استفاده می‌کنند. استاندارد ISBN-10 از مدول 11 استفاده می‌کند، که امکان شناسایی جابجایی‌های تک را فراهم می‌کند.

حافظه و آدرس‌های کامپیوتر: RAM معمولاً در توان‌های 2 (1024، 2048، 4096 بایت در هر صفحه) آدرس‌دهی می‌شود. زمانی که یک برنامه به حافظه دسترسی پیدا می‌کند، سیستم‌عامل از مدول برای محاسبه اینکه یک آدرس در کدام صفحه حافظه قرار دارد استفاده می‌کند: شماره_صفحه = آدرس mod اندازه_صفحه. انتخاب خط کش در کش‌های CPU به همین شکل از مدول استفاده می‌کند. پیچش بافر در پردازش صوتی، صف‌بندی بسته‌های شبکه و جریان ویدئو همگی از ریاضی بافر دایره‌ای استفاده می‌کنند: موقعیت_نوشتن = (موقعیت_نوشتن + 1) % اندازه_بافر.

الگوهای هنر و موسیقی: الگوهای ریتمیک در نظریه موسیقی با استفاده از حساب مدولی تحلیل می‌شوند. یک امضای زمانی 4/4 دارای تک‌تک‌ها 0، 1، 2، 3 تکراری است — یک چرخه مدول 4. پلی‌ریتم‌ها زمانی رخ می‌دهند که دو ریتم مستقل با دوره‌های m و n به صورت همزمان پخش شوند؛ آن‌ها هر lcm(m,n) تک‌تک همزمان می‌شوند. الگوهای بصری مانند تessellations کاشی با دوره‌های مدولی در دو بعد تکرار می‌شوند.

محاسبات جغرافیایی و منطقه زمانی: اختلافات UTC از −12 تا +14 متغیر است. تبدیل بین منطقه‌های زمانی: با توجه به زمان T در UTC، زمان محلی = (T + اختلاف) mod 24. مقدار حاصل ممکن است غیرمعقول به نظر برسد (مثلاً 23 + 5 = 28، mod 24 = 4، به معنی 4:00 صبح روز بعد)، اما عملیات مدول مرز نیمه‌شب را به درستی کنترل می‌کند. عبور از خط تاریخ بین‌المللی از مدول 24 در ترکیب با محاسبات روز هفته با استفاده از مدول 7 استفاده می‌کند.

درک مدول این محاسبات روزمره را روشن‌تر، سریع‌تر و کمتر مستعد خطا می‌کند. هنگامی که الگو را مشاهده می‌کنید، حساب مدولی را در بهینه‌سازی‌های کامپایلر، الگوریتم‌های چرخش در بازی‌های ویدئویی، برنامه‌ریزی مسابقات دوره‌گرد و تعادل بار در کلاسترهای سرور — همگی متکی به مفهوم ساده اما قدرتمند باقی‌مانده پس از تقسیم — مشاهده خواهید کرد.