جاواسکریپت: ۱۰- لوپ
حلقه تکرار – Iterative Loop
گاهی شما میخواهید قطعهای از کد، چندین بار اجرا شود. در این صورت باید از حلقه تکرار استفاده کنید.
هر حلقه ای باید شرطی برای پایان تکرار داشته باشد. اگر نه هنگامیکه کامپیوتر در حلقه میافتد هیچگاه از آن خارج نخواهد شد. و نرمافزار اصطلاحا هنگ خواهد کرد. گاهی این شرط را در آغاز حلقه کنترل میکنند و گاهی در پایان آن و گاهی هم در میانه.
در جاواسکریپت حلقه تکرار را به سه گونه میتوان نوشت.
- do
- while
- for
همه آنها را باید یاد گرفت و در هر جایی، آن روشی را که سادهتر است، به کار برد.
Do-loop
در حلقه do درستی شرط در پایان حلقه بررسی میشود. در صورت درست بودن شرط به ابتدای حلقه برمیگردد و آنرا یک بار دیگر اجرا می کند. و اگر شرط نادرست باشد حلقه دیگر تکرار نخواهد شد و اجرای کد از بعد از حلقه ادامه پیدا میکند.
do { … } while (condition)
let i = 0;
do {
console.log(i);
i++; // i = i + 1;
} while (i < 5);
// output: 0, 1, 2, 3, 4
اگر بدنه حلقه تکرار تنها یک خط داشته باشد، به کرلی برکت {} نیازی نیست.
let i = 0;
do console.log(i++); while (i < 5);
// output: 0, 1, 2, 3, 4
در شرط حلقه تکرار اگر از عمل افزایش یا کاهش درجا استفاده میکنید:
- اگر علامتها قبل از متغیر باشد قبل از مقایسه انجام میشود.
let i = 0;
do console.log(i); while (++i < 5);
// output: 1, 2, 3, 4
- اگر علامتها بعد از متغیر باشد بعد از مقایسه انجام میشود.
let i = 0;
do console.log(i); while (i++ < 5);
// output: 1, 2, 3, 4, 5
به دلیل آن که شرط حلقه do در پایان کار بررسی میشود؛ حتی اگر شرط نادرست باشد، حداقل یک بار اجرا می شود.
let i = 10;
do {
console.log(i);
++i;
} while (i < 5);
// output: 10
مثال: فاکتوریل – Factorial
در ریاضیات به حاصل ضرب همه اعداد طبیعی کوچکتر یا مساوی آن عدد فاکتوریل آن عدد میگویند.
1! = 1
2! = 1 x 2 = 2
3! = 1 x 2 x 3 = 6
4! = 1 x 2 x 3 x 4 = 24
5! = 1 x 2 x 3 x 4 x 5 = 120
...
n! = 1 x 2 x 3 x 4 x 5 x ... x n
در مثال زیر یک عدد از کاربر گرفته میشود و فاکتوریل آن محاسبه و در زیر آن نمایش داده میشود.
- متغیر n: در آغاز کار یک عدد طبیعی را از کاربر میگیرد و آن را در متغیر n قرار میدهد. سپس با هر چرخش در حلقه یکی از آن کم می شود تا به صفر برسد. آنگاه از حلقه خارج میگردد.
- متغیر f: این متغیر برای محاسبه فاکتوریل است. در آغاز کار مقدار آن برابر با یک است. و با هر بار تکرار در عدد بعدی ضرب میشود.
<input type="text" id="in-box">
<button id="btn">OK</button>
<h1 id="out-box"></h1>
const inBox = document.getElementById("in-box");
const outBox = document.getElementById("out-box");
const btn = document.getElementById("btn");
btn.onclick = function() {
let n = inBox.value;
let f = 1;
do {
f *= n; // f = f * n;
--n; // n = n - 1;
} while (n); // n != 0
outBox.innerHTML = f;
}
میتوان عمل کاهش n را در عمل قبلی یا بعدی ادغام کرد در این صورت چون حلقه تکرار یک خط بیشتر ندارد، به کرلی برکت نیازی نیست.
do f *= n--; while (n);
// Or
do f *= n; while (--n);
While-loop
در حلقه while درستی شرط، هر بار در آغاز حلقه بررسی میشود. در صورت درست بودنِ شرط، وارد حلقه میگردد و آنرا یک بار اجرا میکند. و اگر شرط نادرست باشد، اصلا وارد حلقه نمیشود و اجرای کد از بعد از حلقه ادامه پیدا میکند.
while (condition) { … }
let i = 0;
while (i < 5) {
console.log(i);
i++; // i = i + 1;
}
// output: 0, 1, 2, 3, 4
اگر بدنه حلقه تکرار تنها یک خط داشته باشد، به کرلی برکت نیازی نیست.
let i = 0;
while (i < 5) console.log(i++);
// output: 0, 1, 2, 3, 4
در شرط حلقه تکرار اگر از عمل افزایش یا کاهش درجا استفاده میکنید:
- اگر علامتها قبل از متغیر باشد قبل از مقایسه انجام میشود.
let i = 0;
while (++i < 5) console.log(i);
// output: 1, 2, 3, 4
- اگر علامتها بعد از متغیر باشد بعد از مقایسه انجام میشود.
let i = 0;
while (i++ < 5) console.log(i);
// output: 1, 2, 3, 4, 5
در شرط while اگر شرط از پیش نادرست باشد، دستورات درون حلقه while حتی یکبار هم اجرا نمیشوند.
let i = 10;
while (i < 5) {
console.log(i);
++i;
}
// output:
تفاوت do و while
- حلقه do همیشه دست کم یکبار اجرا میشود.
- حلقه while میتواند حتی یکبار هم اجرا نشود.
مثال: فاکتوریل – Factorial
در مثال زیر یک عدد از کاربر گرفته میشود و فاکتوریل آن محاسبه و در زیر آن نمایش داده میشود.
- متغیر n: در آغاز کار یک عدد طبیعی را از کاربر میگیرد و آن را در متغیر n قرار میدهد. سپس با هر چرخش در حلقه یکی از آن کم می شود تا به صفر برسد. آنگاه از حلقه خارج میگردد.
- متغیر f: این متغیر برای محاسبه فاکتوریل است. در آغاز کار مقدار آن برابر با یک است. و با هر بار تکرار در عدد بعدی ضرب میشود.
<input type="text" id="in-box">
<button id="btn">OK</button>
<h3 id="out-box"></h3>
const inBox = document.getElementById("in-box");
const outBox = document.getElementById("out-box");
const btn = document.getElementById("btn");
btn.onclick = function() {
let n = inBox.value;
let f = 1;
while (n) { // n != 0
f *= i; // f = f * i;
n--; // n = n - 1;
}
outBox.innerHTML = f;
}
میتوان عمل کاهش n را در عمل قبلی یا بعدی ادغام کرد در این صورت چون حلقه تکرار یک خط بیشتر ندارد، به کرلی برکت نیازی نیست.
while (n) f *= n--;
// Or
while (--n) f *= n;
For-loop
حلقه for پیشرفتهترین نوع حلقه است. مثل حلقه while شرط آن ابتدای حلقه بررسی میشود. با این تفاوت که از یک متغیر به عنوان شمارنده (Counter) برای تعداد چرخش در حلقه، استفاده میکند.
قبل از ورود به حلقه به متغیر شمارنده مقدار اولیه داده می شود. سپس شرط حلقه بررسی میشود. در صورت درستی شرط وارد حلقه شده آن را یک بار اجرا میکند. سپس مقدار شمارنده تغییر میکند. و به ابتدای حلقه برمیگردد.
for (begin; condition; step) { … }
متغیر i به عنوان شمارنده تعریف میشود و در ابتدا مقدار صفر میگیرد. و در صورتیکه از ۵ کوچکتر باشد، دستورات حلقه را اجرا میکند. و هر بار پس از اجرای حلقه یک واحد به i اضافه میشود. و دوباره شرط بررسی میشود…
for (let i = 0; i < 5; i++) {
console.log(i);
}
// output: 0, 1, 2, 3, 4
اگر بدنه حلقه تکرار تنها یک خط داشته باشد، به کرلی برکت نیازی نیست.
for (let i = 0; i < 5; i++) console.log(i);
// output: 0, 1, 2, 3, 4
مثال: فاکتوریل – Factorial
در مثال زیر یک عدد از کاربر گرفته میشود و فاکتوریل آن محاسبه و در زیر آن نمایش داده میشود.
- متغیر n: یک عدد طبیعی را از کاربر میگیرد و آن را در متغیر n نگهمیدارد.
- متغیر i: متغیر i شمارنده است؛ و مقدار آن در آغاز کار برابر با یک است و با هر بار تکرار در حلقه یکی به مقدار آن افزوده میشود تا از n بزرگتر گردد. آنگاه از حلقه خارج میشود.
- متغیر f: این متغیر برای محاسبه فاکتوریل است. در آغاز کار مقدار آن برابر با یک است. و با هر بار تکرار در عدد بعدی ضرب میشود.
<input type="text" id="in-box">
<button id="btn">OK</button>
<h1 id="out-box"></h1>
let inBox = document.getElementById("in-box");
let outBox = document.getElementById("out-box");
let btn = document.getElementById("btn");
btn.onclick = function() {
let n = inBox.value;
let f = 1;
for (let i = 1; i <= n; i++) {
f *= i; // f = f * i;
}
outBox.innerHTML = f;
}
به دلیل آنکه یک خط بیشتر نیست، به کرلی برکت نیازی نیست.
for (let i = 1; i <= n; i++) f *= i;
// Or
for (let i = n; i > 0; i--) f *= i;
شرط میانی
با گذاشتن یک شرط در میان حلقه میتوانید روند اجرای دستورات را به دو صورت تغییر دهید:
۱- جهش به بیرون حلقه
با دستور break به طور کل از حلقه خارج میشود و به اولین خط پس از حلقه منتقل میشود.
while (...) {
...
if (...) break;
...
}
۲- جهش به دور بعدی حلقه
با دستور continue بقیه دستورات این دور از حلقه اجرا نمیشود و به پایان این دور منتقل میشود.
while (...) {
...
if (...) continue;
...
}
تمرین ۱
اعداد اول اعدادی طبیعی هستند که بر هیچ عددی بجز خودشان و عدد یک بخشپذیر نباشند.
- این فایل را دانلود کنید.
- آن را در فولدر js1 باز کنید.
- تنها فایل script.js را میتوانید تغییر دهید.
- هرگاه روی دکمه کلیک شد، مشخص کند عدد خانه بالا اول است یا خیر و نتیجه را در خانه پایین بنویسد.
تمرین ۲
گوتفرید ویلهلم لایبنیتس (به آلمانی: Gottfried Wilhelm Leibniz) (۱۶۴۶–۱۷۱۶)، دانشمند آلمانی بود. او بنیادگذار دستگاه اعداد دودویی است. که اساس کار کامپیوترهای امروزی است. او برای محاسبه عدد پی نیز یک فرمول ارائه کرد.
- این فایل را دانلود کنید.
- آن را در فولدر js1 باز کنید.
- تنها فایل script.js را میتوانید تغییر دهید.
- هرگاه روی دکمهها کلیک شد، حاصل سری عدد پی را به تعداد خانه اول را در خانه دوم بنویسد.