Информатика ғылымында «алгоритм» түсінігі ақпарат түсінігі сияқты негізгі ұғымдардың бірі болып табылады.
«Алгоритм» сөзі атақты араб математигі Әбу Жафар Мухаммед ибн Мұса әл-Хорезми (763—850 жж.) есімінің латындық транскрипциясы болып табылады. Ол санаудың ондық санау жүйесінде көпорынды сандар мен арифметикалық амалдардың орындалу ережесін ұсынған. Бұл ережелер қосынды мен көбейтіндіні табуға арналған амалдарды орындауға қажетті тізбектен құрылған. Сол ереже осы күнге дейін қолданылып келеді.
Алгоритм деп берілген есептің шығару жолын реттелген амалдар тізбегі түріне келтіруді айтамыз. Кез келген есептің шешу кезеңін қарапайым амалдар тізбегіне бөлектеуге болады. Алгоритмді компьютерде орындау үшін оны программа түрінде жазып шығу керек.
Программа деп машина тілі түсінетіндей, инструкциялар тізбегі түрінде жазылған алгоритмді айтамыз. Программа командалар тізбегінен тұрады. Командалар тізбегі орындалған кезде есептің нәтижесі шығады. Әрбір компьютер алдын-ала құрылған программа бойынша жұмыс жасайды.
Алгоритм ұғымын толығымен түсіну үшін оның қасиеттерін білу қажет. Және де компьютерде орындалатын алгоритмге қойылатын талаптарды білу керек:
алгоритм нақты және анық берілуі қажет;
модульдік қасиетке ие болуы керек (яғни, алгоритмді қарапайым кіші бөліктерге бөлу мүмкіндігі болу керек);
белгілі бір уақыт аралығында бір нәтижеге келу, яғни, алгоритм қадамдарының саны шексіз болмауы керек;
бір тектес есептерге жалпы бір ғана алгоритмді қолдану.
Сергіту жаттығулары (2 мин)
1. Алгоритмнің айқын, дәл өрнектелу қасиеті. Алгоритмде көрсетілген барлық әрекеттер анық, нақты және белгілі болу керек. Онда көрсетілген қадамдар ғана орындалуы керек.
2. Алгоритмнің дискреттік (үзіктілік) қасиеті. Үлкен алгоритмді кіші модульдерге бөлу мүмкіндігі болу керек. Бұл қасиет бойынша алгоритмді кіші бөліктерге бөліп, аралық нәтижені бақылауға мүмкіндік алуға болады. Алгоритмді 2-3 бөлікке бөліп, оның әрқайсына бөлек алгоритм құруға болады.
3. Алгоритмнің нәтижелілік қасиеті. Кез келген алгоритм белгілі бір нәтижеге әкелуі қажет. Белгілі бір уақыт аралығында белгілі бір қадам орындалған соң біз бір нәтиже алуымыз керек.
4. Алгоритмнің жалпылық немесе ортақтық қасиеті. Алгоритм тек бір ғана есепке емес, бір типті есептерге жалпы болуы керек. Мұндай қасиет жалпылық қасиет деп аталады. Мысалы, квадрат теңдеудің түбірлерін табатын алгоритм тек қана бір есепке емес, барлық квадрат теңдеу есептеріне арналған болуы керек.
Алгоритмді жазу тәсілдері.
Алгоритмді компьютерде орындау үшін оны белгілі бір заңдылықтарға сәйкес өңдеу керек. Алгоритмді жазудың бірнеше тәсілдері бар:
1. Табиғи тілде
2. Арнайы түйінді сөздер – терминдер, псевдокодтар арқылы жазу. Яғни, қарапайым алгоритмдік тілдер қолдану.
3. Блок-схема түрінде графикалық кескіндеу.
4. Программалау тілінде жазу.
Осының ішінде алгоритмді блок-схема түрінде жазу және одан кейін оны программалау тіліне аудару кеңінен қолданылады.
Алгоритмді графикалық кескін түрінде жазу – кеңінен қолданылатын тәсіл. Алгоритм схемасын блок-схема деп атайды.
Атауы
Блок-схема түрі
Негізгі әрекеттері
Процесс
Математикалық өрнектерді есептеу
Таңдау
Шартқа сәйкес есептеу жолын таңдау
Модификация
Циклдің басы (қайталау)
Енгізу және шығару
Берілгендерді енгізу және шығару
Басы, соңы
Алгоритмнің басы және соңы
Қосалқы программа
Қосалқы программа шақыру
4)Жаңа тақырыпты бекіту (20-25 мин)
Тапсырмалар мен сұрақтар:
Алгоритм қасиеттері?
Алгоритмнің формальды орындалуы дегеніміз не?
Алгоритмді жазу тәсілдері?
Блок-схема дегеніміз не?
Қандай блок-схема түрлерін білесіңдер?
Блок-схема құру үшін қандай ережелерді білесің?
Тапсырма . Жұмыс дәптеріңе орында.
x – тің кез келген мәні үшін у = (ах3 + b) / (cx3– d) функциясының блок –схемасын құр.
5)Сабақты қорытындылау және бағалау
Оқушыларға алгоритм ұғымы және оның қасиеттері туралы мағлұмат беру. Алгоритмге блок-схема құруды үйрету.
6) Үйге тапсырма §1.1, 1.3, 1.4, 1,5, бет. 4-16
Алгоритм, программа ұғымдары. Алгоритм қасиеттері. Алгоритм жазу тәсілдері. Алгоритм график түрінде кескінделуі.
3) с – ны х – ке көбейтіп, оны У2 деп белгілейміз;
4) У2 –ден d – ны алып тастаймыз, оны У3 деп белгілейміз;
5) У1 –ді У3 –ке көбейтіп, нәтижені У4 деп белгілейміз.
Көрсетілген пункттерді өзгертуге болмайды. Олар дәл осы қалпында орындалуы қажет. Сонда ғана қажетті нәтижеге жетуге болады.
Қалааралық телефонды қолдану алгоритмі.
Телефон тұтқасын алу;
8 санын теру;
Үзіліссіз үнді күту;
Керекті қаланың кодын теру;
Абоненттің телефон нөмірін теру;
Абонент жауабын күту;
Сөйлесу батырмасын басу;
Сөйлесуге болады.
Осы мысалдағы әрекеттерді орындау үшін алдын-ала абоненттің телефон нөмірін, тұратын қала кодын білу қажет.
Жалпы алғанда, өміріміздің барлығы алгоритм тізбектерінен тұрады десек те болады.
Алгоритм орындалу барысында атқарушы қандай инструкция келесі орындалу керектігін біледі. Атқарушы орындай алатын командалардың жиынын атқарушы командалар жүйесі деп атаймыз.
Сонымен, алгоритм атқарушысы алдын-ала қойылған әрекеттерді орындап, нәтижеге жететін адам, компьютер немесе техника болуы мүмкін. Егер есепті шешу үшін техникалық құралдар пайдаланылса, орындалатын әрекеттер тізбегі нақты және түсінікті болу керек. Қаншалықты әрекеттер түсінікті де, нақты болса, соншалықты нәтижеге жету тез және дұрыс болады.
Сергіту жаттығулары (2 мин)
5)Жаңа тақырыпты бекіту (10-15 мин)
Тапсырмалар мен сұрақтар:
Алгоритм дегеніміз не? Алгоритм сөзі қайдан шыққан?
Программа дегеніміз не?
Атқарушы дегеніміз не? Мысал келтір.
Алгоритм командасы дегеніміз не?
Атқарушы – адам мен атқарушы – машина айырмашылығы қандай?
Атқарушы командалар жүйесі дегеніміз не?
Тапсырма №1.
Өзіңе таныс бірнеше (3) алгоритмді мысалға келтір. Жұмыс дәптеріңе пункттер бойынша жаз.
Тапсырма №2. Жұмыс дәптеріңе орында.
У функциясының мәнін табу алгоритмдерін жаз:
а) y=(5x2 – 4)(x2 + 7);
b) y=(4x + 2)2 + x3;
Тапсырма №3. Жұмыс дәптеріңе орында.
Келесі алгоритм бойынша У функциясының формуласын тап.
а)
1) х – ті х – ке көбейтіп, нәтижені а1деп белгілеу;
Пайдаланылған әдебиеттер:1) Б.Бурибаев. Информатика және ЕТ негіздері, оқулық 9 сынып;
2) Основы информатики и ВТ, базовый курс 10-11 класс;
3) С.Т.Мухамеджанова, «Методика обучения информатике»
4)Динисламов, «Паскаль программалау негіздері» Сабақ барысы
Ұйымдастыру кезеңі (2 мин):
а) оқушылар тізімі;
ә) кабинет жағдайы;
б) сабақ барысымен таныстыру.
Үй тапсырмасын тексеру.(3-5мин)
Алгоритм дегеніміз не? Алгоритм сөзі қайдан шыққан?
Программа дегеніміз не?
Атқарушы дегеніміз не? Мысал келтір.
Алгоритм командасы дегеніміз не?
Атқарушы – адам мен атқарушы – машина айырмашылығы қандай?
Атқарушы командалар жүйесі дегеніміз не?
Жаңа тақырыпқа кіріспе (3-5 мин)
Жаңа тақырыпты түсіндіру(3-5 мин)
Алгоритм құрылымына қарай оны келесі типтерге бөлуге болады:
Сызықтық алгоритмдер. Сызықтық алгоритм қарапайым командалар тізбегінен тұрады. Әрекеттердің тізбектей орындалуын сипаттайтын алгоритм – сызықтық алгоритм деп аталады.
Тармақталу алгоритмі. Күнделікті өмірде алгоритмдер негізінен тармақтарға бөлінеді. Бұл тармақтардың орындалуы шарттың орындалуына байланысты болады. Тармақталу алгоритмінде біріншіден, арифметикалық теңсіздік түрінде берілген логикалық шарт тексеріледі. Егер шарт орындалса, алгоритм бір тармақ бойынша (1-ші серия) , ал егер орындалмаса, екінші тармақ бойынша (2-ші серия) орындалады.
Циклдік алгоритмдер. Көптеген алгоритмдерде белгілі бір әрекеттер бірнеше рет орындалады. Математикада, есеп шығару барысында айнымалы мәні өзгеруіне байланысты бір теңдеудің көмегімен бірнеше рет есептеледі. Алгоритмнің белгілі бір бөлігі бірнеше қайталанатын болса, ондай процессті цикл деп атайды. Қайталанатын бөлігі бар алгоритмдер циклдік алгоритм деп аталады. Циклдік алгоритмдер қолдану арқылы программаны қысқа да нұсқа жазуға болады. Қайталану бөлігіне қайталану (циклдік) командалары қолданады. Қайталану саны белгілі немесе белгісіздігіне байланысты циклдар екі түрге бөлінеді. Қайталану саны белгілі болса, ондай цикл арифметикалық, ал егер белгісіз болса, итерациялық деп аталады.
Арифметикалық цикл Итерациялық цикл
Сергіту жаттығулары (2 мин)
5)Жаңа тақырыпты бекіту (10-15 мин)
Тапсырмалар мен сұрақтар:
Алгоритмнің типтері?
Сызықтық алгоритм дегеніміз не? Мысал келтір.
Тармақталу алгоритмі дегеніміз не? Мысал келтір.
Циклдік алгоритм дегеніміз не? Мысал еклтір.
Тапсырма №1. Жұмыс дәптеріңе орында.
Бес сан берілген: a, b, c, d, f. Осы сандардың қосындысын, көбейтіндісін және орташа мәнін есептейтін алгоритм блок-схемасын құр. Сызықтық алгоритм.