Подпрограмма-функция.
Программирование с использованием подпрограмм.
Обособленную группу операторов, оформленную специальным образом, которую можно выполнять многократно, обращаясь к ней из различных мест программы, называют подпрограммой. Чтобы подпрограмма при обращении к ней выполнялась каждый раз с новыми данными, ее нужно составить в общем виде, а исходные данные для работы передавать в переменные подпрограммы перед обращением к ней.
Это подпрограмма имеет следующую структуру:
FUNCTION имя [(список параметров) STATIC]
[Операторы подпрограммы]
имя = выражение
END FUNCTION
Для обращения к функции используют указатель функции содержащую имя функции и в скобках конкретные значения ее аргументов.
Результат выполнения подпрограммы- функции в главную программу передается через локальную переменную, имя которой должно совпадать с именем подпрограммы.
Пример 10. Вычислить , где
.
Сумму вычислить с точностью 0,0001.Для этого необходимо суммировать до тех пор, пока очередной член суммы не станет меньше заданной точности.
Используем подпрограмму - функцию.
Function R(X)
S = 0: K = 1
While Abs(X ^ K / K ^ 2) > 0.0001
S = S + X ^ K / K ^ 2
K = K + 1
Wend
R = S
End Function
Sub PR10()
U = R(1 / 2) + R(1 / 3) + R(1 / 4)
Cells(1, 1) = "U="
Cells(1, 2) = U
End Sub
Пример 11.Вычислить скалярное произведение векторов:
Используем подпрограмму, вычисляющую скалярное произведение векторов :
.
Sub pr11()
Rem "Основная программа"
k = Cells(2, 1): m = Cells(2, 1)
ReDim a(1 To k), b(1 To k), C(1 To m), D(1 To m)
For i = 1 To k
a(i) = Cells(3 + i, 1): b(i) = Cells(3 + i, 2)
Next
For i = 1 To m
C(i) = Cells(3 + i, 3): D(i) = Cells(3 + i, 4)
Next
S1 = SP(a(), b(), k)
S2 = SP(C(), D(), m)
Cells(2, 5) = "S1"
Cells(2, 6) = "S2"
Cells(3, 5) = S1
Cells(3, 6) = S2
End Sub
Function SP(X(), Y(), N)
Rem "Подпрограмма"
S = 0
For i = 1 To N
S = S + X(i) * Y(i)
Next
SP = S
End Function
Подпрограмма общего вида (процедура)
Это подпрограмма имеет следующую структуру:
SUB имя [(список параметров)] [STATIC]
Операторы подпрограммы
END SUB
Для обращения к подпрограмме общего вида служит оператор
[CALL] имя подпрограммы [(список аргументов)].
Результаты выполнения подпрограммы - процедуры передаются в главную программу через локальные переменные, указанные в списке параметров. Поэтому, в отличие от подпрограммы – функции, из подпрограммы – процедуры в главную программу можно передать большее количество данных.
Используем подпрограмму общего вида для решения примера 10.
Sub PR10_main()
Rem "Основная программа"
Call P(1 / 2, R1)
Call P(1 / 2, R2)
Call P(1 / 2, R3)
U = R1 + R2 + R3
Cells(1, 1) = "U="
Cells(1, 2) = U
End Sub
Sub P(X, R)
Rem "Подпрограмма процедура"
R = 0: K = 1
While Abs(X ^ K / K ^ 2) > 0.0001
R = R + X ^ K / K ^ 2
K = K + 1
Wend
Для решения примера 11.
Sub pr11_procedura()
Rem "Основная программа"
k = Cells(2, 1): m = Cells(2, 1)
ReDim a(1 To k), b(1 To k), C(1 To m), D(1 To m)
For i = 1 To k
a(i) = Cells(3 + i, 1): b(i) = Cells(3 + i, 2)
Next
For i = 1 To m
C(i) = Cells(3 + i, 3): D(i) = Cells(3 + i, 4)
Next
Call SP(a(), b(), k, S1)
Call SP(C(), D(), m, S2)
Cells(2, 5) = "S1"
Cells(2, 6) = "S2"
Cells(3, 5) = S1
Cells(3, 6) = S2
End Sub
Sub SP(X(), Y(), N, S)
Rem "Подпрограмма"
S = 0
For i = 1 To N
S = S + X(i) * Y(i)
Next
End Sub
ЛИТЕРАТУРА
1. Г. Зельднер «Программирование на языке Quick Basic 4 .Б» М.: ABF:1996 г.-186 с.
2. Майкл Маккелви. Visual Basic 4.-М.: Вином,1996.-23 с.
3. Методические указания к расчетно-графическим работам для студентов 1 курса специальностей 2903, 2906, 2907, 2908, 2909, 2910 / КГАСА, Сост.О.В.Бахарева. Казань, 1995, 34 с.
4. Методические указания по курсу "Информатика" для лабораторных и контрольных работ для студентов всех специальностей и направлений подготовки. Основы программирования. /Казанский государственный архитектурно-строительный университет; Сост.: Ф.Г.Ахмадиев, Ф.Г.Габбасов, - Казань, 2012. 44 с.
5. Г.З. Гарбер. «Основы программирования на Visual Basic и VBA в Excel 2007». Москва: «Солон – Пресс», 2008 г.- 191 с.,
РЕЦЕНЗИЯ
на методические указания по курсу "Информатика" для лабораторных и самостоятельных работ для студентов всех специальностей и направлений подготовки.