مرتبه زمانی:
در طراحی الگوریتم هدف استفاده از روشهایی برای کاهش مرتبه زمانی و کاهش تعداد گامهای یک برنامه میباشد. مرتبه زمانی یا Order مدت زمان اجرا یا همان تعداد گامهای اجرای یک برنامه را نشان میدهد. مرتبه زمانی الگوریتمها در دستههای زیر قرار میگیرند.
مثال:
:
for(int i = 0; i < 5; i++)
cout << i;
:
for(int i = 0; i < n; i++)
cout << i;
:
int i = n;
while(i >= 1)
{
i /= 2;
cout << i;
}
:
for(int i = 0; i < n; i++)
{
int j = n;
while(j >= 1)
{
j /= 2;
cout << j;
}
}
:
for(int i = 0; i < n; i++) // O(n)
for(int j = 2; j < n; j++) // O(n)
cout << i * j; // O(n) * O(n) = O(n^2)
تابع بازگشتی
مثال: مقدار را بدست آورید.
int f(int n)
{
if(n <= 1)
return n;
return f(n - 1) + f(n - 1);
}
نکته: معمولاً مسائلی که به صورت درختی حل شوند دارای مرتبه زمانی نمایی هستند.
شمارگامهای یک برنامه:
برای محاسبهی مرتبهی زمانی باید شمار گامهای یک برنامه محاسبه شود، یعنی هر سطر از برنامه چند بار اجرا میشود. در ادامه با چند مثال شمار گامها را محاسبه میکنیم.
int y = 0; // (1)
int x; // (0)
for(int i = 0; i < n; i++){ // (n + 1)
y++; // (n)
x = y; // (n)
} // ________
// (3n + 2)
for(int i = 2; i < n; i++) // (n - 1)
cout << i; // (n - 2)
// ________
// (2n - 3)
for(int i = 0; i < n; i++) // (n+1)
for(int j = 1; j < n; j++) // ( n ) * n
cout << i * j; // ( n ) * (n-1)
// _____________
// 2(n^2) + 1
for(int i = 0; i < n; i++){ // (n+1)
for(int j = 1; j <= n; j++) // ( n ) * (n+1)
cout << i * j; // (n^2)
for(int k = 0; k < n; k++) // ( n ) * (n+1)
cout << k; // (n^2)
} // _______________
// 4(n^2) + 3n + 1
حل معادلات بازگشتی به روش جایگزینی
با استفاده از رابطهی بازگشتی (با جایگذاری) از شروع کرده و به عقب بر میگردیم تا به شرط خروجی یا مقدار اولیه رابطه بازگشتی برسیم.
مثال:
حل:
تمرین:
1. مرتبه زمانی و مقدار را بدست آورید.
int f(int n){
if(n <= 0)
return 2;
return f(n - 1) + n * f(n - 2);
}
2. مرتبه زمانی و شمارگامهای قطعه کد زیر را بدست آورید.
for(int i = 0; i < n - 1; i++)
for(int j = 1; j < m; j++)
for(int k = 0; k <= n; k++)
cout << i * j * k;