توليد اعداد random و تصادفي در جاوااسکريپت

دسته بندی: جاوا اسکریپت
زمان مطالعه: 5 دقیقه
۲۲ بهمن ۱۳۹۰

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

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

:: تولید اعداد اعشاری تصادفی بین صفر و یک :

:: خوب ، بریم سر اصل مطلب . در javascript برای تولید اعداد random از متد ()Math.random استفاده میشه . متد ()Math.random یک عدد اعشاری بین 0 و 1 رو تولید میکنه . به طور مثال اگر شما کد زیر رو درون تگ body در صفحه ی وب قرار بدید یک عدد اعشاری بین 0 و 1 ، با بیش از ده رقم اعشار براتون چاپ میشه .

<script type="text/javascript">
randomNumber = Math.random();
document.write(randomNumber);
</script>

:: خروجی این کد (یک عدد تصادفی اعشاری بین 0 و 1) :  (با رفرش صفحه عددی جدید می‌بینید)

در کد فوق عدد تصادفی توسط متد ()Math.random تولید شده و در متغیر randomNumber قرار میگیره و مقدار این متغیر توسط متد  ()document.write در صفحه ی وب چاپ میشه .

:: تولید اعداد اعشاری تصادفی بین صفر و عددی دلخواه :

حالا اگربخواید اعداد بزرگتری رو به صورت رندم تولید کنید کافیه عدد تولید شده توسط متد رندم رو در حداکثر عدد دلخواهتون ضرب کنید . مثلا اگر میخواید یک عدد رندم بین 0 تا 100 تولید کنید ، همون کد بالا رو به شکل زیر داریم :

<script type="text/javascript">
randomNumber = Math.random() * 100;
document.write(randomNumber);
</script>

:: خروجی این کد (یک عدد تصادفی اعشاری بین 0 و 100) :  (با رفرش صفحه عددی جدید می‌بینید)

:: تولید اعداد صحیح تصادفی بین صفر و عددی دلخواه :

برای اینکه اعداد تصادفی تولید شده رو از حالت اعشاری دربیارید و اعداد رو به صورت صحیح و بدون قسمت اعشاری داشته باشید باید از متد ()Math.floor استفاده کنید . این تابع یک عدد اعشاری رو به عنوان ورودی میگیره و خروجیش جزء صحیح اون عدد هست . جزء صحیح همون بزرگترین عدد صحیح کوچکتر از یک عدد اعشاریه . پس برای تولید اعداد صحیح بین 0 تا یک عدد دلخواه مثل 100 ، کد رو به شکل زیر داریم :

<script type="text/javascript">
randomNumber = Math.floor(Math.random() * 100);
document.write(randomNumber);
</script>

در این کد ابتدا یک عدد اعشاری بین 0 و 1 توسط تابع random تولید میشه ، بعد ضرب در 100 میشه و سپس عدد حاصل ،که یک عدد اعشاری بین 0 تا 100 هست ، جزء صحیحش توسط متد floor گرفته میشه و در متغیر randomNumber قرار میگیره . :: خروجی این کد (یک عدد تصادفی صحیح بین 0 و 100) :  (با رفرش صفحه عددی جدید می‌بینید)

:: تولید اعداد صحیح تصادفی بین دو عدد دلخواه :

شاید دوست نداشته باشید عدد تصادفی از 0 تا یه عدد دلخواه باشه . و بخواید مثلا عدد تولید شده بین 80 تا 100 باشه . انجام اینکار هم سادست . فرض کنید که می‌خواید اعداد تصادفی تولید شده بین دو عدد x و y باشه . کافیه عدد باند پایین یعنی x رو به عدد رندم تولید شده اضافه کنید و تابع رندم رو به جای اینکه در y ضرب کنید در y-x ضرب کنید . مثلا اگر بخواید اعداد تصادفی تولید شده بین 80 و 92 باشند ، کد رو باید به صورت زیر بنویسید :

<script type="text/javascript">
randomNumber = 80 + Math.floor(Math.random() * 12);
document.write(randomNumber);
</script>

12 همون اختلاف بین 92 و 80 هست ، و 80 رو هم که با عدد تصادفی تولید شده جمع کردیم . در واقع حداقل می‌خواید 80 رو داشته باشید به اضافه ی یک عدد تصادفی بین 0 تا 12 ! :: خروجی این کد (یک عدد تصادفی صحیح بین 80 و 92) :  (با رفرش صفحه عددی جدید می‌بینید)

:: تابع تولید اعداد صحیح تصادفی بین دو عدد دلخواه :

:: در آخر هم یک تابع ساده براتون نوشتم که دیگه نخواید کد اضافه بزنید ! به راحتی می‌تونید کد زیر رو درون تگ head اضافه کنید :

<script type="text/javascript">
function myRandom(start,end){
randomNumber = start + Math.floor(Math.random() * (end-start));
return randomNumber;
}
</script>

و درون تگ body به همین راحتی از اون استفاده کنید(که در مثال زیر چهار بار برای دامنه‌های مختلف عددی استفاده شده) :

<script type="text/javascript">
document.write(myRandom(0,3)+'<br>');
document.write(myRandom(10,20)+'<br>');
document.write(myRandom(100,1000)+'<br>');
document.write(myRandom(1000,2000)+'<br>');
</script>

تگ br هم که استفاده شده برای نمایش هر عدد در یک خط جدید است . :: خروجی کد (چهار عدد تصادفی در دامنه‌های ذکر شده در کد) :  (با رفرش صفحه اعداد نو میبینید)

اگر این مقاله رو خوب خونده باشید ، می‌دونید که این تابع روش کارش چطور بوده . :: دوستان عزیز ، برای نوشتن این مقالات وقت گذاشته شده و زحمت کشیده شده . لطفا در صورت انتشار این مطلب در وبگاهتون منبع رو ذکر کنید . با تشکر فراوان . :: چیز دیگه مونده در مورد تولید اعداد تصادفی؟

چه امتیازی به این مقاله می دید؟
نویسنده لقمان آوند
بیش از 15 سال هست که برنامه نویسی می کنم و از بین همه زبون هایی که کار کردم جاوا، اسمبلی و php رو دوست دارم. دانشجوی دکترای نرم افزارم و توی دانشگاه روی پردازش بیگ دیتا و پردازش موازی کار کردم و عاشق چالش از هر نوعیش هستم! سون لرن مثل بچه منه که 12 سال براش وقت گذاشتم، اینجا همه تلاش می کنیم از شروع یادگیری تا ورود به بازر کار حوزه برنامه نویسی و IT همراهتون باشیم.

نظرات کاربران

شلیر

سلام من باید اشعار حافظ رو توی یک ارایه قراربدم وبعد با کلیک روی یه دکمه فال بگیره.
ولی اصلا انجام نمیشه
ابزارهای شماهم کار نمیکنه برای یه سایت تمرین کلاسی میخوام
سپاس

مهدی

سلام
من میخام عکس هدر وبلاگم به صورت تصادفی نغییر کنه
برای این کار اولا باید عدد تصادفی تولید کنم و بعدش یه چیزی مانند if در زبان c داشته باشم تا به یکی از عکس ها ارجاع بدم 💡
من از بلوگفا استفاده میکنم
میشه یه نمونه کد بدین؟
ممنون میشم اگه به ایمیلم جواب بدین
خیلی مرسی 😉

hassan

استاد گفته باید با for درست بشه

hassan

اگه کد جاواشو برام بفرستین ممنون میشم html شو بلدم مرسی

لقمان آوند

خوب سادست که . ضرب دو عدد تصادفی بین 0 تا 100 .
var n1= Math.floor(Math.random() * 100);
var n2= Math.floor(Math.random() * 100);
var m=n1*n2;

hassan

خسته نباشید آره دو عدد انتخاب کنه و به صورت تصادفی ضرب کنه

hassan

SALAM KHASTE NABASHID
man ye barnameh mikham ke zarb 2 adad be sorat tsadofi njam bedeh

لقمان آوند

یعنی چی ؟ یعنی دو عدد رندم انتخاب کنه و اونا رو ضرب کنه ؟ خوب از طریقی که در این پست گفته 2 تا عدد رندم بدست بیار و در هم ضرب کن .

پروانه

سلام ببخشید میشه منابع این مطالب رو بگید از کجان؟
از رو چه کتابایی..مقالاتی..استفاده کردید
لازم دارم مرسی

لقمان آوند

سلام
این مطلب رو خودم نوشتم . از دونسته های قبلی و از جای خاصی استفاده نشده .

پروانه

میشه کتابی بهم معرفی کنید راجع به روشهای تولید اعداد تصادفی؟

لقمان آوند

در این رابطه کتابی نمی شناسم . صفحه ویکی پدیا این مطلب رو بخونید . شاید کمکی کنه :
http://en.wikipedia.org/wiki/Random_number_generation

nasim

salam , saytetun kheyli khube matalebasham kheyli gabele fahm tozih dade sgode ,man mikham ye sayti tarahi konam vase madrese ki bacheha bian un sayto bebinan matalebike mikhan bardaran pul variz konan sabtenam konan va… bayad che barnameyiro balad basham ?
chetori saytamo tu internet garar bedam? mer30

محمدسینا معراجیان

دو حالت داره یا خودتون برنامه نویسی میکنید که حداقل به دونستن.html , css نیاز دارید
یا میخواید همه چی براتون. آماده نصب شه که اون فقط کافیه به فضای مجازی بخرید توضیح بیشتر لازم بود بفرمایید عرض کنم
پایدار باشید

مهرنوش

سلام ببخشید میخوام یه برنامه به زبان سی که بااستفاده ازتابع رندوم برای تابع بازگشتی برج هانوی 4عددتصادفی تولید کنه که 3تاش برای انتخاب تصادفی میله ها ویکی هم برای تعد اد دیسک باشه.تعدادی دیسک بااستفاده از میله کمکی م تب کنه.لطفا راهنمایی بفرمایید یابرنامه بفرستیدبه ایمیلم خیلی ممنون میشم..همشهریتون هستم دانشجوی مهندسی پزشکی پیام نورشیرازم[email protected]

لقمان آوند

برای تولید عدد رندم در c باید کتابخانه stdlib.h رو اینکلود کنید ، بعد از تابع رندم به این شکل استفاده کنید : (برای تولید عدد رندم بین 0 تا 5) :
random(6);
خود 6 تولید نخواهد شد …

رضا

😥 😥 😥 😥 دیگه جوابمو نمیدین؟ 😕 😕 😕

لقمان آوند

سلام رضا جان
سوالی ندیدم از شما !

رضا

من بلد نیستم دیتابیس بسازم یه مدل کوچیک فقط 5 تا عدد بسازید تروخدا

لقمان آوند

سلام
کد ساختن که زمانگیره . ولی کلیتش اینطوره . در یک فایل یا دیتابیس عدد صفر رو در ابتدا ذخیره کن .
یک عدد تصادفی انتخاب کن و با عدد موجود در فایل/دیتابیس جمع کن و نمایش بده و جمع حاصل رو به جای عدد قبلی ذخیره کن .
هر بار اینکار رو انجام بده .

ارسال دیدگاه
خوشحال میشیم دیدگاه و یا تجربیات خودتون رو با ما در میون بذارید :