Автор работы: Пользователь скрыл имя, 22 Ноября 2012 в 20:30, реферат
Егер сіз берілген есепті шешу үшін қандай да бір программалау тілінде программа жазғыңыз келсе, онда алдымен есепті шешудің алгоритмін құруыңыз керек. Алгоритм – математикадағы ең бір іргелі ұғымдардың бірі. Алгоритм сөзі ІХ ғасырда өмір сүрген, адамдардың квадрат теңдеулерді жүйелей құрып оны шеше білуге үйреткен ұлы математик Әл- Хорезмидің атының латынша жазылуы algorithmi сөзінен алынған.
Ықыласпен тоқылық
Оқысанңыз балалар
Шамнан шырақ жағылар
Тілегенің алдыңнан іздемей-ақ табылар.
Әзір циклі
BASIC тілінде циклді мектептік алгоритмдік тілдегі жазылуымен салстырып былай жазуға болады.
Әзір <шарт>
k IF NOT P THEN k+30
цб
<әрекет> k+20 GONO k
цс
Мұнда к-қатарда шартты өту операторы тұр, ол қойылған шарт «сакталмаған» жағдайда басқаруды к+30-қатарға, яғни «қайталану командасынан» шығару құрылғысына береді. Цикл к+10-қатардан басталып циклдің денесіне сай келетін к+20-қатардағы шартсыз өту операторымен аяқталады, содан кейін басқаруды қайтадан шартты тексеру қатарына береді. Осылайша, мектептік алгоритмдік тілдегі сияқты цикл қайталана береді.
Төменде циклдің бұл түрінің блок-схемасы BASIC тіліндегі жазылуымен салыстырылып көрсетілген.
Мұнда командалар тізбегі шартты тексеруден орналасқан. Мұндай жағдайда шартқа байланысты цикл денесі бір рет те орындалмауы мүмкін. Циклдің бұл түрін ӘЗІР циклі деп атайды.
Дейін циклі
Бұл циклдің блок – схемасы мына суретте көрсетілген.
Жоқ
иә
k Командалар тізбегі
k+10 IF NOT шарт THEN k
k+20 REM цикл соңы
Циклдің
бұл түрінде командалар
Мысалы, ДЕЙІН циклін пайдаланып х-тің мәні -10-нан +10-ға дейін 2 қадаммен өзгеретін у= х2+в функциясының мәнін есептейтін программа құрыңыздар.
ДЕЙІН циклі бойынша:
Үшін цикілінің BASIC тіліндегі жазылуы.
FOR және NEXT операторлары
Жоғарыда айтылғандай циклді программаларды басқаруды беру операторы IF арқылы ұйымдастыруға болады. Бірақ циклдер программа жасаудағы ең маңызды және кеңінен тараған құрылым болғандықтан практикада BASIC программалау тілінде оларды ұйымдастыру үшін арнайы
FOR және NEXT операторлары қарастырылған. Бұл операторларды циклдік программаның ұзындығын қысқарту үшін және BASIC тіліндегі программада циклдерді анық ажыратып бөліп көрсету үшін пайдаланады.
Мектептік алгоритмдік тілде параметрі бар қайталану командасын Үшін цикілі деп атайды. Оның жазылу пішімі мынадай:
Цб: үшін і1 бастап і2 дейін
цикл денесі (командалар тізбегі)
Цс
BASIC программалау тілінде Үшін циклін жазу үшін FOR операторы қолданылады. FOR операторын циклдің басының операторы немесе жай ғана циклдің басы деп атайды. Олар әр уақытта қайталанатын командалар тізбегінің, яғни циклдің денесінің алдында келеді. Сонымен цикл басының жазылу пішімі мынадай болады:
k FOR v=e1 TO e2 STEP e3.
Мұнда к-қатар нөмірі, v-циклдің параметрі, e1, e2-цикл параметрінің бастапқы және соңғы мәндері, TO (дейін) – қызметші сөздер, STEP (қадам) – қызметші сөз, e3-цикл параметрі қадамының өзгерісі, яғни өсімшесі.
Программа
жасағанда FOR операторынан соң
циклдің денесін құрайтын
k NEXT v
Мұнда k-қатар нөмірі, NEXT-(келесі) оператордың аты; v-циклдің параметрі. Ол міндетті түрде FOR операторындағы параметрмен сәйкес келуі тиіс. Сонымен, BASIC тілінде цикл былай ұйымдастырылады:
k FOR v=e1 TO e2 STEP e3
FOR және NEXT операторларын
пайдалану ережелері
Бұл оператордың көмегімен циклді программалауда мына төмендегі ережелерді ескеру қажет.
1. FOR операторын қолданып циклге ендіруге рұқсат етілмейді. Яғни циклдің денесін құрайтын операторға сырттан басқаруды беруге болмайды. Сырттан басқаруды беруде е1,е2,е3 өрнектің мәні есептелмейді. Егер е1,е2,е3 айнымалы немесе тұрақтылар болса,
онда олардың мәні анықталмайды.
Сырттан басқаруды берудің мүмкін еместігіне мысал;
30. FOR I = N + 2 TO 20
40. Y (I) = X (I) + 5
50. NEXT I
60. A =A -3
70. IF A I=15 THEN 40
Мұнда 70-операторымен басқаруда 40-қатардағы циклдің ішкі параметірге беруге болмаиды.
2. Кез келген уақытта цикілден шақыруға рұқсат етіледі. Мысалы;
.
20. K = 1
30. FOR I = 1 TO 10
40. K = K + 1
50. IF K – 10 THEN 70
60. NEXT I
70. PRINT K, I
.
программа үзіндісіне циклдің программасын қателікпен алып келіуі мүмкін болғандықпен алдын ала анықтауға кеңес беруге болмайды.
3. Циклдің санын қатаң сақтауы, бүтін болуы тиіс.
30. FOR I % = 1 TO 2 %
.
90. NEXT I %
Циклден шығаруда цикл программаның сонғы мәні сақталады.
Пайдаланушы анықтайтын функция
Есептер шығару барысында элементар функциялар: sinx, cosx, tnx, ex және т.б. жиі қолданылады. Бұл функцияларды стандартты математикалық функциялар деп аталады, оларды программаның кез келген жерінде алгебралық өрнектерде қолдануға болады. Функциялардың аргументтері міндетті түрде жақшаға алынып жазылады.
Кейде есеп
шығаруда осы аталған
K DEF FN v(x1,x2,…,xN)=e
Мұнда k-қатар нөмірі; DEF (анықта)- оператордың аты; FNV- пайдаланушы анықтайтын функцияның аты; (v- программалаушы таңдап алатын латын әріпі); х1, х2, …,хN- формальды аргументтер тізімі; е- арифметикалық өрнек. Мысалы,
30 DEF FN B(X,Y)=X^ 2+Y^2
Стандартты
емес, яғни пайдаланушы анықтайтын
функцияның аты барлық уақытта
үш латын әріпінен құралады, ал
үшінші әріпті пайдаланушы өзі
таңдайды. Тек қарапайым, (индекстері
жоқ) үтірлерімен бөлінген
Ереже
бойынша формальды аргументтер
е арифметикалық өрнегіне де
енеді. Оған санымен бірге
Мысалы,
мына төмендегі функцияны есепт
Мұнда түрінде жазуға болатын формула көптеген рет пайдаланылған. Программа бұл формуланы DEF операторының көмегімен функция ретінде анықтау орынды. Сонда программаның түрі мынандай болады:
10 REM
20 DEF FNY (X)=3*X^2+COS (X)