.

Початкові відомості про алгоритмічну мову Паскаль (реферат)

Язык: украинский
Формат: реферат
Тип документа: Word Doc
0 2977
Скачать документ

Реферат з інформатики

Початкові відомості про алгоритмічну мову Паскаль

1. Лексика мови Паскаль та загальний вигляд програми

Кожна мова починається з алфавіту – скінченної множини символів. Алфавіт
мови Паскаль складають:

великі й малі латинські букви A, B, … , Z, a, b, …, z;

десяткові цифри 0, 1, 2, …, 9;

інші символи, серед яких + – * / = > , >, =, 2 – true, 1>=1 –
true тощо. Операції порівняння називаються відношеннями.

Є кілька операцій, що задаються дещо незвично, у вигляді f(…), де f –
ім’я. Вирази такого вигляду називаються викликами функцій. Наприклад,
вираз вигляду odd(x) задає обчислення ознаки непарності: значенням
odd(7) є true, odd(12) – false.

До цілих чисел застосовні й інші операції (розд. 10).

Через скінченність множини цілих чисел, представних у комп’ютері, багато
операцій із цілими визначені частково. Так, не всякі два числа можна
додати або умножити, оскільки результат може виявитися не представним у
комп’ютері. Наприклад, maxint+1 або maxint*2.

Отже, ми визначили, хоча і не точно, множину “цілих чисел” Z і множину
операцій O, застосовних до них. Пара

(МНОЖИНА ЕЛЕМЕНТІВ, МНОЖИНА ОПЕРАЦІЙ ІЗ НИМИ)

у математиці називається типом. Множина елементів називається носієм
типу, а множина операцій – його сигнатурою. Тип (Z, O) називається типом
цілих і в мові Паскаль позначається ім’ям integer.

Тип цілих значень називається скалярним, оскільки ці значення
розглядаються як неподільні, тобто такі, що не складаються з окремих
частин. Далі ми познайомимося з іншими скалярними типами мови Паскаль.
Вони називаються базовими типами цієї мови. Ми також познайомимося із
структурними типами. Їх елементи, на відміну від скалярних, складені з
частин, які можна позначати окремо.

Задача

2.2.3. Булів тип

Сталі false і true позначають бульові значення “хибність” і
“істина”. До них застосовні
операції “та”, “або”, “не”, що називаються відповідно бульовим
множенням (кон’юнкцією), бульовим додаванням (диз’юнкцією) і
запереченням. В мові Паскаль вони позначаються знаками and, or і not.
Крім бульових операцій, означено операцію “порядковий номер” ord:
ord(false)=0, ord(true)=1. Порядковим номерам бульових значень
відповідає результат їх порівняння: false , >, =.

Отже, ми означили тип, що називається бульовим і позначається ім’ям
Boolean на честь видатного англійського математика й логіка Джорджа
Буля, засновника математичної логіки.

Завдання:

Указати значення, що утворюються в результаті застосування операцій:

а) (2*2=4) and true; б) (2*2=4) or false;

в) (not true) or false

2.2.4.Вирази: процес обчислення та значення

Ціла або бульова стала є виразом. Складніший вираз утворюється з
простішого або простіших як

1.вираз у дужках;

2.два вирази й знак бінарної операції між ними;

3.вираз із знаком унарної операції перед ним;

4.виклик функції з виразом у дужках.

Ось приклади виразів: ((1)), true and false, 1-(2+3), (1-2)+3, (1+2)3,
-(5+3), odd(2), ord(odd(15)).

Те значення, до якого застосовується операція, називається її операндом.
Операнди позначаються виразами.Найпростішими з них є сталі. Вираз задає
застосування операцій до операндів – значень простіших
виразів.Послідовність виконання цих операцій утворює процес обчислення
значення виразу.

Як бачимо, вираз має подвійний зміст, або семантику: З одного боку, він
задає процес обчислення, а з іншого –він має значення. Наприклад, вираз
2*2=4 задає процес, у якому обчислюється добуток 2*2 і порівнюються два
цілі значення 4 і 4, в результаті чого одержується значення true.

Таким чином, на питання про те, що таке “2*2=5”, математик відповів би,
що це неправильна рівність, а програміст – що це позначення обчислень.

Результати операцій у процесі обчислення виразу запам’ятовуються для
застосування до них подальших операцій. Останнє з обчислених значень
також запам’ятовується для використання в програмі. Проміжні значення
запам’ятовуються, як правило, в регістрах процесора, оскільки робота з
ними відбувається набагато швидше, ніж робота з оперативною пам’яттю.

Як використовуються вирази? Їх значення можна іменувати, присвоювати
змінним, виводити “у зовнішній світ”або використовувати для прийняття
рішень про те, що робити далі при виконанні програми. Всі ці незрозумілі
слова ми почнемо пояснювати, починаючи з пункту 2.2.5.

Мова Паскаль в основному дотримується угод, що склалися в математиці про
порядок застосування операцій у виразах. Це дозволяє не записувати зайві
дужки, наприклад, усі розуміють, що 1-2*3 означає те ж саме, що і
1-(2*3). На порядок застосування операцій за відсутності дужок впливає
їх старшинство, або пріоритетність. Якщо поруч із позначенням операнда
записано знаки двох операцій, то спочатку виконується

старша з них, що має більш високий пріоритет.Всі операції (не тільки над
цілими) розбито на чотири групи,розташовані в порядку спадання
пріоритету. Операції всередині кожної групи мають однакові пріоритети.
Наприклад, вираз 1+(3+2)*2 задає, що після обчислення 3+2, тобто 5, воно
множиться на 2, а не додається до 1.

Крім властивостей старшинства, операції мають властивості право- або
лівобічного зв’язування. У стандарті мови Паскаль усі двомісні операції
мають властивість лівобічного зв’язування: якщо ліворуч і праворуч від
позначення операнда записано знаки операцій з однаковим старшинством, то
спочатку застосовується записана ліворуч. Наприклад,

1-2*4+3 = (1-2*4)+3, але аж ніяк не 1-(2*4+3).

Застосування операцій, указаних у виразі, можна подати таким чином.
Відшукаємо операцію, яка виконується першою, та від позначення її
операндів проведемо стрілки вниз, і там запишемо результат. Потім
зробимо те саме з операндами наступної операції, потім третьої тощо,
поки не одержимо результат обчислення виразу

Тип значення, обчислення якого задає вираз, називається типом виразу.

2.2.5. Іменування виразів із сталими

Вираз із сталими, записаний у програмі, обчислюється не при виконанні
програми, а в процесі трансляції.Значення такого виразу можна позначити
ім’ям (іменувати) і використовувати це ім’я далі в програмі.Іменування
має вигляд

const ім’я = вираз із сталими;

(ключове слово const означає “стала”). Іменування є означенням імені,
яке після означення можна записувати впрограмі замість виразу.

Корисно іменувати вираз, що записується в багатьох місцях програми, або
“непостійно постійні”, що можуть змінитися з часом уже після того, як
створено програму, наприклад, деякі величини в економічних задачах.

Якщо вираз іменований, то зміну потрібно внести лише в іменування, а
якщо ні – доведеться змінювати вираз скрізь, де він зустрічається.

За словом const можна записати кілька іменувань, відокремивши їх “;”,
причому у виразах можна використовувати імена вже іменованих виразів,
наприклад:

const a=12; b=2*a; tt=a+b;

Ім’я tt після цього позначатиме 24.

Саме з іменування виразів найчастіше починаються Паскаль-програми.

2.3. Вирази та оператори

2.3.1. Імена та змінні

Поняття змінної числової величини вперше з’явилося в роботах геніального
француза Рене Декарта. Воно багато в чому визначило подальший розвиток
математики. Пізніше, із створенням математичної логіки та теорії множин,
виявилося, що змінна величина може бути не обов’язково числовою, а мати
значеннями, наприклад, “істину” й

“хибність” або множини елементів найрізноманітнішого походження. Так,
можна говорити про змінну істинність фрази “тут зараз світить сонце” або
про змінну множину команд Ліги чемпіонів з футболу.

У найзагальнішому значенні змінна величина – це узагальнення, абстракція
якогось реального чи уявного об’єкта, або його окремої характеристики,
що може перебувати в різних станах. Змінна звичайно позначається ім’ям,
наприклад, у другому законі Ньютона a=F/m у фізиці імена m, a, F
позначають змінні величини – масу тіла, прискорення його руху, та силу,
що діє на нього. Як правило, змінна в міркуваннях ототожнюється з її

ім’ям, і це не призводить до непорозумінь. Проте, ми майже завжди будемо
відрізняти позначення від того, що ним позначено.

У програмуванні змінна також є представником об’єкта, але “міркує” тепер
комп’ютер, тому змінна – це ділянка пам’ятіі, що своїми станами подає
стани об’єкта.

У програмах мови Паскаль (та інших мов високого рівня) змінні
позначаються іменами, або ідентифікаторами.

Імена можна вибирати будь-які, крім службових слів. Наприклад,
ABRACADABRA, temperature, number, f1234qq тощо. У багатьох діалектах
імена різняться тільки по перших восьми символах, наприклад, імена
abcdefgh1 і abcdefgh2 невідрізнювані.

Змінна величина у математиці вважається заданою, якщо визначено множину
значень, які вона може приймати.

У Паскаль-програмі змінна задається означенням, де записується її ім’я й
тип:

var ім’я : ім’я типу;

наприклад,

var temperature : integer;

або

var even : boolean;

Ключове слово var є скороченням англійського variable – змінна). Кілька
однотипних змінних можна означити

разом, указавши їх імена через кому:

var a, b, c: integer;

Тип змінної задає множину її можливих значень, і операції, застосовні до
них. Наприклад, цілі значення змінної temperature можна до чогось
додавати або від чогось віднімати, а до значень змінної even можна
застосовувати операцію заперечення, але не навпаки.

Кожна ділянка пам’яті має в комп’ютері щось на зразок номера – адресу.
Саме адресою вказується ділянка пам’яті в машинній програмі. Ім’я
змінної, записане в Паскаль-програмі, в результаті трансляції
перетворюється на адресу деякої ділянки пам’яті програми. При виконанні
програми ця ділянка і є тією змінною, чиє ім’я записано в

програмі. Ми кажемо, що ім’я змінної вказує, або посилається на ділянку
пам’яті під час виконання програми, або що ділянку поставлено у
відповідність імені

Проте поки незрозуміло, звідки в змінних беруться значення. Зараз
дізнаємося.

2.3.2. Оператор присвоювання

Оператор присвоювання має вигляд:

ім’я змінної := вираз

(знак присвоювання “:=” – це лексема, яку не слід плутати зі знаком
порівняння “=”). Оператор присвоювання позначає:

1) обчислити значення виразу, записаного праворуч;

2) записати це значення в змінну, позначену ім’ям.

Отже, описані дії є семантикою оператора присвоювання.

Приклад. Якщо ім’я z означено як var z : integer, то оператор
присвоювання z:=11*(10+1) позначає обчислення значення 121 і запис його
в змінну з ім’ям z. Після його виконання змінна з ім’ям z має значення
121.?

Пара вигляду (ім’я, значення) називається станом змінної, наприклад,
(z,121) – стан змінної z після виконання оператора присвоювання. Таким
чином, після присвоювання змінній нового значення її стан змінюється.

Оператори присвоювання (і не тільки вони) в програмі записуються один за
одним і відокремлюються роздільником “;”, наприклад, z:=1; t:=2
(звичайно, за умови, що z і t означено як імена змінних типу integer).

Оператори, записані один за одним, утворюють послідовність операторів.
Кожен з них задає зміну стану хоча б однієї зі змінних.

Сукупність змінних, чиї імена означено в програмі, називається пам’яттю
програми. Сукупність станів змінних називається станом пам’яті програми.
Зміна стану однієї зі змінних змінює стан пам’яті програми, тому
оператор присвоювання задає зміну стану пам’яті програми. Далі ми
розглянемо інші види операторів, але всі оператори задають зміну станів
пам’яті програми. Ця зміна і є їхньою семантикою.

Виконання операторів програми можна проімітувати, указавши їх
послідовність і послідовність станів пам’яті програми, що утворюються в
результаті їх виконання. Якщо в процесі виконання програми змінна ще не
одержала значення, то воно вважається невизначеним і позначається “?”.
Наприклад, ось програма та подання її імітації:

program a2(input, output);

var x, y, z : integer;

begin

z := 1;

????†††††††††††††††††††††††††?????††††††††††††††††††††††????††††††††††††
††††††††††??

Звернімо увагу на те, що нові значення змінних записуються замість
старих.

2.3.3. Вирази з іменами

Імена змінних, присвоювання значень яким задано в попередніх операторах
програми, можна записувати у виразах. Значенням виразу, складеного лише
ім’ям змінної, є значення цієї змінної, присвоєне їй раніш.
Наприклад,якщо змінна з ім’ям z має значення 2, то вираз z+1 задає
додавання 2 і 1; значенням виразу буде 3. При іншому значенні z вираз
z+1 мав би інше значення. Породження значення змінної за її ім’ям
називається її розіменуванням.

Приклад. Послідовність операторів z:=2; z:=z+1 задає присвоювання
змінній z спочатку 2, а потім обчислення 2+1 і присвоювання 3 цій же
змінній. Сам по собі оператор z:=z+1 задає збільшення значення змінної з
ім’ям z на 1, яким би це значення не було (аби воно було присвоєно).

Отже, ім’я змінної у виразі задає її значення в момент обчислення
виразу. Тому ми кажемо, що вираз обчислюється при поточних значеннях
вказаних у ньому змінних, або на поточному стані пам’яті. Наприклад,
послідовності операторів x:=2; z:=x+1 і x:=5; z:=x+1 задають
присвоювання різних значень (3 і 6) змінній z у результаті виконання
того самого оператора z:=x+1.

Крім імен змінних, у виразах можна записувати іменовані сталі. Вони
також розіменовуються, наприклад, якщо означено const cc=169, то вираз
cc-25 має значення 144. Зазначимо, що він обчислюється в процесі
трансляції програми.

Завдання

1). Написати вираз, значенням якого є true тоді й тільки тоді, коли дві
прямі, задані цілими коефіцієнтами рівнянь вигляду

ax+by+c=0:

а) паралельні й не збігаються; б) паралельні (можливо, збігаються);

в) збігаються; г) перетинаються; д) перпендикулярні.

2)Написати послідовність операторів, що задає обмін значень двох змінних
за умови:

а) можна використовувати третю змінну;

б) третю змінну не використовувати, але змінні числові.

2.3.4. Обчисли й напиши

Комп’ютер виведе значення виразу на екран, якщо написати цей вираз в
“операторі” запису, або виведення:

writeln(вираз)

Насправді цей “оператор” є викликом спеціальної програми, що називається
“процедура запису writeln” (від англійського write line – “записати
рядок”). При її виконанні комп’ютер обчислює значення виразу, за цим
значенням створює відповідну сталу, тобто послідовність символів, і
передає її пристрою, частиною якого є екран. І вже в цьому

пристрої стала друкується на екрані. Наприклад, при виконанні операторів
програми з цілою змінною z

z:=1; writeln(1+z);

writeln(z2)

на екрані з’явиться 124true.

У “операторах” виведення нарівні з виразами можна записувати
послідовності символів у апострофах,наприклад, ‘x=’, ‘123’ тощо. Вони
називаються рядковими сталими, або літералами, і виводяться так само, як
записані в програмі, тільки без апострофів. Наприклад, за операторами

x:=2; writeln( 1, ‘) x=’, x, ‘; x2=’, x*x, ‘; x2>2 : ‘, x*x>2 )

на екран виводиться

1) x=2; x2=4; x2>2 : true.

За виразом у “операторі” виведення можна написати двокрапку і за ним
цілу сталу, наприклад, x+y:10. Стала задає так звану ширину поля, у яке
виводяться символи значення виразу. Якщо кількість символів менше, ніж
ця ширина, то спочатку виводяться пропуски (доповнюючи символи до ширини
поля), а якщо символів більше, то виводяться всі вони. Наприклад, при
виконанні операторів

x:=10; writeln(‘x=’, x:5, ‘, x2=’, x*x:1)

на екран перед 10 виводиться три пропуски, а також усі цифри 100:

x= 10, x2=100

Ще один “оператор” виведення, а точніше, процедура write (“записати”),
відрізняється від процедури writeln лише тим, що при її виконанні після
виведення останньої сталої курсор не пересувається в наступний рядок
екрана. Наприклад, при виконанні операторів

x:=2;

write(‘x=’, x);

write(‘, x2>2 : ‘, x*x>2)

на екран виводиться

x=2, x2>2 : true

і курсор залишається праворуч від останньої букви “e”.

За допомогою “операторів” writeln і write можна задавати виведення не
лише на екран, але й на інші носії даних,наприклад, у файли на диску.
Але про це далі

Завдання

1)Написати програму виведення на екран числа 16, його квадрата 256 і
куба 4096 в одному рядку через два пропуски. Сталих 256 і 4096 явно не
використовувати.

2.3.5. Читання, або присвоювання “із зовнішнього світу”

Оператор присвоювання – не єдиний спосіб, у який задається присвоювання
значень змінним. Змінна може одержати значення “із зовнішнього світу”
при виконанні “оператора” читання, або введення, що у найпростішому
випадку має вигляд readln( им’я-змінної ). Насправді це виклик
спеціальної програми, що називається “процедура

читання readln” (від англійського read line – прочитати рядок).

При виконанні “оператора” читання

readln ( им’я-змінної )

комп’ютер зупиняється й чекає, що на клавіатурі буде набрано сталу того
ж типу, що й тип указаної змінної. У відповідь слід набрати якусь сталу
на клавіатурі (вона відображається на екрані). Але нічого не
відбудеться, якщо після цього не натиснути на клавішу “Enter”. Тільки
після “Enter” цю сталу, тобто послідовність символів, буде передано від
клавіатури в комп’ютер, а він за цією сталою обчислить відповідне
значення та присвоїть змінній.

Якщо натиснути “Enter”, не набравши сталу, то комп’ютер продовжить своє
чекання. Перед числовою або бульовою сталою можна набрати також довільне
число пропусків.

Якщо замість сталої набрати щось інше, наприклад, сталу іншого типу, то
виконання програми на цьому авершиться (аварійно), і на екрані
з’являться образливі слова про те, що вхідні символи були неправильними.

Наприклад, якщо при виконанні оператора readln(z), де ім’я z позначає
цілу змінну, набрати 1024 і натиснути”Enter”, то значенням z стане 1024,
а якщо набрати z=1024, то програма аварийно завершиться, тому що ціла
стала не може починатися символами “z=”.

У “операторі” введення можна написати кілька імен змінних, відокремивши
їх комами. При його виконанні треба набрати відповідну кількість сталих,
відокремивши їх пропусками або натисканнями на клавішу “Enter” у
довільній кількості. І поки всі сталі не будуть набрані, виконання
такого “оператора” не закінчується.

Приклад. Нехай x : integer, y : boolean. При виконанні readln(x,y) слід
набрати цілу сталу, потім додати хоча б один пропуск або натискання на
“Enter”, а потім натиснути на клавіші t, r, u, e або f, a, l, s, e,
тобто набрати бульову сталу

true або false. І не забути натиснути на “Enter” наприкінці.

І ще одне зауваження з приводу використання readln. Практично перед
кожним “оператором” читання з клавіатури не завадить написати “оператор”
запису з запрошенням до введення значень і поясненням, яких саме типів і
в якій кількості. Наприклад, якщо x1, x2 означено як цілі:

writeln(‘введіть два цілих числа’);

readln(x1, x2).

Без такого запрошення невідомо, що робити тому, хто запустив програму на
виконання, і чи виконується вона взагалі. Не уподібнюйте свої програми
мовчазним привідам.

Операторами readln задається читання не лише з клавіатури, але також і з
інших зовнішніх носіїв, наприклад,файлів на диску.

Завдання

Написати програму читання двох чисел a й b та:

а)* друкування їх суми; б) друкування, чи вірно, що a

Нашли опечатку? Выделите и нажмите CTRL+Enter

Похожие документы
Обсуждение

Ответить

Курсовые, Дипломы, Рефераты на заказ в кратчайшие сроки
Заказать реферат!
UkrReferat.com. Всі права захищені. 2000-2020