Автор работы: Пользователь скрыл имя, 05 Июня 2015 в 08:33, курсовая работа
Программа құрылымы
Программа келесі бөлімдерден тұруы мүмкін, бұл бөлімдер (тек соңғыдан басқасы) бір-бірінен нүктелі-үтір арқылы ажыратылады:
программа тақырыбы;
белгілер бөлімі;
тұрақтылар бөлімі;
типтерді сипаттау бөлімі;
процедура мен функцияларды сипаттау бөлімі;
программа денесі;
Паскаль тілінің негізгі түсініктері..............2
1.1 Турбо паскаль тілінің операторлары .........4
Негізгі бөлім
1.2 Циклдік құрылымды алгоритмді программалау....5
1.3 Алғы шартты цикл операторы. While операторы ..........6
1.4 Келесі шарт бойынша циклді ұйымдастыру.
Repeat операторы................8
1.5 Параметрлі қайталану операторы.
For операторы.......9
1.6 Күрделі циклдер..............11
1.7 ЭЕМ-де есеп шығару кезеңдері.
Қадам бойынша орындау әдісі......................11
1.8 Мысал есептер..............................12
Қайталау (цикл).................................19
2.0 Сызықты және тармақты құрылымды алгоритмдерді программалау....21
2.1 Қайталанған құрылымды алгоритмдерді программалау.....28
Қорытынды
Әдебиеттер тізімі..........................20
Case m of
Qbasic, Pascal тілдерінде циклды ұйымдастыру
Qbasic тілінде “әзірше”
циклын IF жәнеWHILE –WEND операторлары
бойынша құруға болады.WHILE (әзірше)
операторының құрамына
Qbasic тілінде әзірше циклы төмендегі құрылымдар бойынша жазылуы мүмкін:
1) DO WHILE P
2) DO
S
S
LOOP
Мұндағы DO, WHILE, LOOP – (орындау, әзірше, айналу) қызметші сөздер, P – шарт, S – цикл денесі.
Pascal тілінде “әзірше” циклінің жазылу түрі: WHILE P DO S
WHILE P DO – цикл тақырыбы; WHILE (әзірше), DO (орындау ) – қызметші сөздер (DO соңына нүктелі үтір қойылмайды);
P –шарт (логикалық немесе бульдік өрнек); S – цикл денесі.
.
Qbasic тілінде “дейін” циклының “әзірше ” циклынан айырмашылығы “дейін” циклында шартты тексеруден бұрын цикл денесі бір рет орындалады. ”Дейін” циклы төмендегі құрылымдар бойынша жазылуы да мүмкін:
1) DO UNTIL P 2) DO
S
LOOP
Pascal тілінде “дейін” циклының жазылуы:
REPEAT S UNTIL P
Repeat – цикл тақырыбы, UNTIL – циклдың аяқталу шарты. Repeat (қайталау), Until (дейін) – қызметші сөздер. Олар операторлық жақша ролін атқарады.
Until қызметші сөзінің алдындағы оператордан соң нүктелі үтір қойылмауы тиіс.Until қызметші сөзінен кейін соң жазылған шарт жақшаға алынбауы мүмкін.
Qbasic тілінде “үшін” циклы. Егер қайталаулар саны алдын ала белгілі болса, онда циклды FOR – NEXT (for – үшін,next - екелесі) операторлар арқылы ұйымдастырған тиімді.
“Үшін” циклының жазылуы:
FOR K=K TO K [STEP H]
NEXT <[цикл параметрі]>
FOR – цикл басының операторы немесе цикл тақырыбы, NEXT – цикл соңын көрсететін оператор, K – цикл параметрі немесе цикл санауыш немесе басқарушы айнымалы деп аталады. K мен K - параметрдің бастапқы және соңғы мәндері (H – қадам ұзындығы, S – цикл денесі), STEP (қадам), TO (дейін). Егер H=1 болса, STEP H қызметші сөзін жазбаса да болады.
Pascal тілінде “үшін” циклының жазылуы:
FOR <цикл параметрі>:=<бастапқы мән>
TO <соңғы мән > DO S
немесе FOR<цикл параметрі>:=<
DOWNTO <соңғы мән> DO S
Мұндағы FOR … DO цикл тақырыбы; FOR (үшін), TO (дейін), DOWNTO (төменге дейін) –қызметші сөздер; цикл параметрі Integer типті айнымалы. Мұнда бастапқы және соңғы мәндер өрнек түрінде берілуі де мүмкін.
FOR циклында параметр Integer типті болса, оның қадамы 1 не -1 мәндерінен өзгеше болуы мүмкін емес (FOR – TO циклында қадам 1-ге, FOR – DOWNTO циклында қадам - 1-ге тең). Қадамның басқа мәндерінде WHILE не REPEAT циклын пайдалану керек.
Qbasic.Pascal тілдерінде күрделі циклдарды ұйымдастыру
Бірінің ішінде бірі салынған бірнеше қарапайым циклды күрделі цикл деп атайды. Күрделі циклдарды сыртқы және ішкі циклдар деп бөледі. Біріне – бірі салынған цикл санын күрделі циклдың тереңдігі деп аталады. Күрделі циклдарды “үшін” циклының операторы арқылы құруға болады. Qbasic тілінде FOR арқылы берілетін цикл ішінде циклдың жазылу түрі:
FOR K =K TO K
Мұндағы J – ішкі цикл параметрі, K – сыртқы цикл параметрі.
Pascal тілінде FOR арқылы берілетін цикл ішінде циклдың жазылу түрі:
2.1 Қайталанған құрылымды
Qbasic, Pascal тілдерінде сандық массивтер
Программалау тілдерінде бір типті шамаларды массивке біріктіруге болады. Аты біртекті элементтердің реттелген жиыны массив болып табылады. Ол математикада вектор ұғымына, ал мектептің алгоритмдік тілінде сызықтық кестеге сәйкес келеді. Массивтің аты жай айнымалының атын құрғандағы ережелерге сүйеніп құрылады. Массивтің әрбір элементіне соңынан индексі келетін массивтің аты меншіктеледі. Сондықтан да массив элементтерін индексті айнымалылар деп те атайды. Ұйымдастыру тәсілдері бойынша программалву тілдерінде бір өлшемді және екі өлшемді массивтер пайдаланылады. Бір өлшемді массив ретінде векторды, ал екі өлшемді массив үшін матрицаны қарастыруға болады.
Qbasic тілінде бір өлшемді массив. Кез келген сан немесе айнымалы шаманың мәнін өз жадында сақтау үшін ЭЕМ оған сәйкес ұяшық бөледі. Ал құрамында көп мәні бар массивтер үшін белгілі мөлшерде ұяшық бөлуге тиіс. Массивтер Бейсик тілінде DIM операторы арқылы сипатталынады. Оның жазылу тәртібі мынадай:
DIM <айнымалы> (индекстер); <айнымалы> - массив аты, оның соңына элементтер типін сипаттау символы енгізілуі тиіс (%,$); индекстер – ең соңғы элементтің индекстері. Мысалы, DIM A$ (5).
Pascal тілінде бір өлшемді массив. Массив элементтерін және оның атауын белгілеу Бейсик тіліндегі белгілеулерге ұқсас. Паскаль тілінде бір өлшемді массивтің жазылу тәртібі мынадай:
Type <тип атауы> = array[P1] of P2;
Var < массив атауы>:=<тип атауы>;
Мұндағы, array[P1] of P2 - массивті анықтау; P2 - массив элементтерінің типі (оны негіздік тип деп атайды);
P1 - элемент индексінің типі (ол Integer, Real типтерінен басқа кез келген жай тип болуы мүмкін. Әдетте ол үшін аралық тип алынады); тип атауы – типті (массивті) анықтайтын кез келген белгілеме (айнымалы);
массив атауы – типі тип атауынан тұратын айнымалы;
TYPE (тип), ARRAY (массив), OF – қызметші сөздер.
Qbasic тілінде екі өлшемсді массив. Екі өлшемді массивке мысал, математикадығы матрица бола алады. Екі өлшемді массивтердің элементтері екі индекспен көрсетіледі, оның біріншісі қатардың номері, ал екіншісі бағанның номерін анықтайды. Екі өлшемді массивтерде индекстер үтірмен бөлінеді . Программалау тілдерінде индекстер нөлден бастап нөмірленеді. Екі өлшемді массивтің жазылуы:
DIM A$(3,3) . Индекстің ең кіші мәні нөл, ал ең үлкен мәні DIM операторында белгіленген мәннен асып кетпеуі керек. Егер индекстің мәні бұл шекарадан асып кетсе, онда программаны орындауда, қателік кеткендігі жөнінде хабар экранға шығады. Массивтерді цикл ішінде , FOR және NEXT операторларын қолданып өңдеген ыңғайлы. Бұл жағдайда цикл параметрі циклдің санын санау қызметін атқарады және массив элементтерінің индексін белгілеуде қолданылады.
Pascal тілінде екі өлшемді массив. Паскальда екі өлшемді а массивін былай жазуға болады:
type ms = array [1..3,1..3] of P;
Var a:ms;
P – массив элементінің типі .
Qbasic,Pascal тілдерінде ішкі программа және процедура
Барлық программалау тілдерінде ішкі программалар жиі қолданылады. Бейсик программалау тілінде қосалқы алгоритмдер ішкі программа түрінде жазылады. Ішкі программа:
- алгоритмнің қайталанатын
бөлігін бір рет жазып,
одан кейін оны
- күрделі программаны өте ықшамды және түсінікті түрде сипаттауға мүмкіндік береді.
Ішкі программа өзінше дербес программа бола отырып, негізгі программамен бірігіп жұмыс істейді. Ішкі программа негізгі программа сияқты өзінің орындалу нәтижесінде белгілі бір есепті толық шешіп бере алады. Ішкі программаның негізгі программадан айырмашылығы, оның өзбетінше орындала алмайтындығында. Ішкі программа міндетті түрде негізгі программа ішінде орындалуы тиіс. Ішкі программаларды жасаудағы бір ерекшелік, оны негізгі программаға қайтаратын арнайы оператор болады.
Qbasic тілінде көмекші программа құрудың бір құрылымдық тәсілі SUB – END SUB операторын пайдалану. Оның жазылу түрі:
SUB<атау> (айнымалылар тізімі) [STATIC]
S
END SUB
(SUB(subroutine – көмекші (қосалқы, бағынышты) программа; static – айнымалыларды өзгермейтін етіп қабылдау).
Мұндай құрылымдық көмекші программаны процедура деп атайды. Процедураны шақыру командасы (операторы) – CALL . Оның жазылу түрі (call - шақыру ):
CALL <атау> (айнымалылар тізімі)
Шақыру командасына call қызметші сөзін енгізбеуге де болады. Программаның негізгі бөлімі мен процедурада пайдаланылатын айнымалылар бірдей болады. Программа басына осы үшін арналған COMMON SHARER <айнымалылар тізімі>. Мұнда ескеретін жайт, программаның Sub espt(x) қатарын енгізген кезде жаңа процедура бөлімі (модуль) терезесі ашылады да,
SUB
END SUB
түрінде жазылған процедура форматы көрінеді.
Pascal тілінде ішкі программа және процедура. Паскаль тілінде көмекші программа толық программа түрінде құрылып, негізгі программаның VAR бөлімінен соң орналасылады. Олардың саны бірнеше болуы мүмкін.
Процедура тақырыбы көмекші программаны анықтаушы PROCEDURE қызметші сөзінен басталып, оның оң жағына процедураның атауы енгізіледі. Одан әрі жай жақшалар ішінде формальды параметрлер сипатталады да, тақырыптың соңына нүктелі үтір символы қойылады. ОЛ процедура тақырыбын өзінің басқа бөлімдерінен ажырату белгісі.
Тақырыптан соң негізгі программадағы сияқты сипаттау бөлімдерінің енгізілуі мүмкін. Бұдан әрі BEGIN, END қызметші сөздерімен шектелген операторлар бөлімі жазылады да, END – тен соң нүктелі үтір таңбасы қойылады:
Procedure<атау>[(<типтері сипатталған
[<сипаттау бөлімдері>]
Begin
операторлар бөлімі
end;
Процедурада пайдаланылған t айнымалысы – нақты параметр мәнін қабылдайтын, ал P айнымалысы - мәні есептеліп нақты параметрге меншіктелетін формальды параметрлер. Соңғы BEGIN, END операторлық жақшаларының ішінде жазылғандар – программаның операторлар бөлімі. Программаның орындалуы осы оператордан басталады. Негізгі программаға енгізілген espt(xk, yk) – espt атаулы процедураны шақыру операторы. Шақыру операторының жазылу үлгісі:
<Процедура аты> [(нақты параметрлер тізімі)];
(тізім үтірлер арқылы бөлініп жазылад
Параметрсіз процедура. Көптеген процедуралар формальды параметрлерді пайдаланбай , нақты параметрлермен тікелей жұмыс істейді. Мұндай параметрсіз процедура тақырыбының жазылу үлгісі:
Procedure <атау>;
Бұл кезде шақыру командасы тек процедура атауынан тұрады.
Qbasic, Pascal тілдерінде пайдаланушы – функциямен жұмыс
Qbasic тілінде пайдаланушының функциясымен (процедура - функцияны) құрылымдық форматта екі түрлі етіп жазу мүмкіндігі бар (Function - функция):
1) DEF FN атау (айнымалылар тізімі)
FN атау=… 'функция
END DEF
2) FUNCTION <атау> (айнымалылар тізімі) [STATIC]
<атау> =…' функция
END FUNCTION
Мұнда мәні есептелетін функция атауы DEF немесе FUNCTION қызметші сөздерінен соң жазылатын атаумен бірдей болуы тиіс. Програманың FUNCTION Y(x) қатарын енгізген кезде, SUB форматы сияқты бөлек терезеде
FUNCTION
END FUNCTION
құрылымы көрінеді.
Pascal
тілінде пайдаланушы – функция.
Информация о работе Сызықты және тармақты құрылымды алгоритмдерді программалау