Основы программирования — Осенний семестр; Михалкович С.С.; 2008; I — различия между версиями

Материал из Вики ИТ мехмата ЮФУ
Перейти к: навигация, поиск
(Система программирования PascalABC.NET)
Строка 1: Строка 1:
 
[[Категория:Основы программирования]]
 
[[Категория:Основы программирования]]
 
[[Страница курса Основы программирования|К основной странице курса]]
 
[[Страница курса Основы программирования|К основной странице курса]]
 +
 +
 +
'''Source(s):'''  [http://downloadranking.com  Основы программирования — Осенний семестр]
 +
  
 
== Алгоритм ==
 
== Алгоритм ==
Строка 8: Строка 12:
  
 
В частности, процессор компьютера выступает исполнителем машинных команд.
 
В частности, процессор компьютера выступает исполнителем машинных команд.
 +
 +
 +
'''Source(s):'''  [http://downloadranking.com  Основы программирования — Осенний семестр]
 +
 +
 
=== Свойства алгоритма ===
 
=== Свойства алгоритма ===
 
* Дискретность — алгоритм представляет собой последовательность элементарных шагов (команд исполнителя).
 
* Дискретность — алгоритм представляет собой последовательность элементарных шагов (команд исполнителя).
Строка 36: Строка 45:
  
 
'''Спецификация задачи''' — точное, однозначное описание задачи. Включает формулировку входных и выходных данных.
 
'''Спецификация задачи''' — точное, однозначное описание задачи. Включает формулировку входных и выходных данных.
 +
 +
 +
'''Source(s):'''  [http://downloadranking.com  Основы программирования — Осенний семестр]
 +
  
 
=== Способы описания алгоритмов ===
 
=== Способы описания алгоритмов ===
Строка 50: Строка 63:
  
 
Для языка программирования команды алгоритма называются '''''операторами''''' или '''''инструкциями'''''.
 
Для языка программирования команды алгоритма называются '''''операторами''''' или '''''инструкциями'''''.
 +
 +
 +
'''Source(s):'''  [http://downloadranking.com  Основы программирования — Осенний семестр]
 +
  
 
=== Основные характеристики алгоритма===
 
=== Основные характеристики алгоритма===
Строка 58: Строка 75:
 
* сложность написания
 
* сложность написания
 
* возможность распараллеливания
 
* возможность распараллеливания
 +
 +
 +
'''Source(s):'''  [http://downloadranking.com  Основы программирования — Осенний семестр]
 +
  
 
=== Основные характеристики программы ===
 
=== Основные характеристики программы ===
Строка 69: Строка 90:
 
Если два алгоритма эквивалентны, то какой из них лучше? Тот же вопрос можно задать о программах, реализующих эти алгоритмы.
 
Если два алгоритма эквивалентны, то какой из них лучше? Тот же вопрос можно задать о программах, реализующих эти алгоритмы.
 
Как правило, не существует однозначного ответа на этот вопрос. Лучшие по скорости алгоритмы как правило более сложны, труднее для понимания и могут требовать больше памяти. Часто для решения задачи не нужна самая быстрая программа - достаточно простой и понятной программы.
 
Как правило, не существует однозначного ответа на этот вопрос. Лучшие по скорости алгоритмы как правило более сложны, труднее для понимания и могут требовать больше памяти. Часто для решения задачи не нужна самая быстрая программа - достаточно простой и понятной программы.
 +
 +
 +
'''Source(s):'''  [http://downloadranking.com  Основы программирования — Осенний семестр]
 +
  
 
=== [http://it.mmcs.sfedu.ru/forum?func=view&id=22184&catid=1 Обзор современных языков программирования] ===
 
=== [http://it.mmcs.sfedu.ru/forum?func=view&id=22184&catid=1 Обзор современных языков программирования] ===
 
(самостоятельно на форуме)
 
(самостоятельно на форуме)
 +
 +
 +
'''Source(s):'''  [http://downloadranking.com  Основы программирования — Осенний семестр]
 +
  
 
== Язык программирования PascalABC.NET ==
 
== Язык программирования PascalABC.NET ==
 
===Правила записи программ на PascalABC.NET===
 
===Правила записи программ на PascalABC.NET===
 
'''[http://it.mmcs.sfedu.ru/files?func=fileinfo&id=24 Шпаргалка]'''
 
'''[http://it.mmcs.sfedu.ru/files?func=fileinfo&id=24 Шпаргалка]'''
 +
 +
 +
'''Source(s):'''  [http://downloadranking.com  Основы программирования — Осенний семестр]
 +
  
 
===Пример программы, вычисляющей  длину и площадь круга===
 
===Пример программы, вычисляющей  длину и площадь круга===
Строка 95: Строка 128:
 
end.  
 
end.  
 
</source>
 
</source>
 +
 +
 +
'''Source(s):'''  [http://downloadranking.com  Основы программирования — Осенний семестр]
 +
  
 
===Структура программы на языке Паскаль===
 
===Структура программы на языке Паскаль===
Строка 107: Строка 144:
  
 
Как правило, программа начинается с ввода исходных данных, после чего следуют вычисления и вывод результатов. Ввод сопровождается приглашением к вводу.
 
Как правило, программа начинается с ввода исходных данных, после чего следуют вычисления и вывод результатов. Ввод сопровождается приглашением к вводу.
 +
 +
 +
'''Source(s):'''  [http://downloadranking.com  Основы программирования — Осенний семестр]
 +
  
 
===Система программирования PascalABC.NET===
 
===Система программирования PascalABC.NET===
Строка 114: Строка 155:
  
 
Отличия языка PascalABC.NET от обычного языка Паскаль.
 
Отличия языка PascalABC.NET от обычного языка Паскаль.
 +
 +
 +
'''Source(s):'''  [http://downloadranking.com  Основы программирования — Осенний семестр]
 +
  
 
=== Компиляторы и интерпретаторы ===
 
=== Компиляторы и интерпретаторы ===
Строка 123: Строка 168:
  
 
'''Синтаксис''' - правила записи конструкций, '''семантика''' - смысл конструкций.
 
'''Синтаксис''' - правила записи конструкций, '''семантика''' - смысл конструкций.
 +
 +
 +
'''Source(s):'''  [http://downloadranking.com  Основы программирования — Осенний семестр]
 +
  
 
== Синтаксис и семантика ЯП ==  
 
== Синтаксис и семантика ЯП ==  
 
// В программе 2013-14 гг. этот пункт будет сокращен и размыт по следующим темам когда будут вводиться основные операторы языка.
 
// В программе 2013-14 гг. этот пункт будет сокращен и размыт по следующим темам когда будут вводиться основные операторы языка.
 +
 +
 +
'''Source(s):'''  [http://downloadranking.com  Основы программирования — Осенний семестр]
 +
  
 
=== Определения ===
 
=== Определения ===
Строка 131: Строка 184:
  
 
'''Семантика''' — описывает смысл конструкций ЯП, а также задает ряд ограничений.
 
'''Семантика''' — описывает смысл конструкций ЯП, а также задает ряд ограничений.
 +
 +
 +
'''Source(s):'''  [http://downloadranking.com  Основы программирования — Осенний семестр]
 +
  
 
=== Способы описания синтаксиса ===
 
=== Способы описания синтаксиса ===
Строка 163: Строка 220:
  
 
'''Замечание 2.''' Синтаксис определяет лексемы языка.
 
'''Замечание 2.''' Синтаксис определяет лексемы языка.
 +
 +
 +
'''Source(s):'''  [http://downloadranking.com  Основы программирования — Осенний семестр]
 +
  
 
=== Лексемы Паскаля ===
 
=== Лексемы Паскаля ===
Строка 174: Строка 235:
 
::<span style="color: green">(*...*)</span>
 
::<span style="color: green">(*...*)</span>
 
::<span style="color: green">//...</span>
 
::<span style="color: green">//...</span>
 +
 +
 +
'''Source(s):'''  [http://downloadranking.com  Основы программирования — Осенний семестр]
 +
  
 
== Переменные и их описание ==
 
== Переменные и их описание ==
Строка 206: Строка 271:
 
  <список имен> ::= <имя>{,<имя>}
 
  <список имен> ::= <имя>{,<имя>}
 
  <тип> ::= <имя>
 
  <тип> ::= <имя>
 +
 +
 +
'''Source(s):'''  [http://downloadranking.com  Основы программирования — Осенний семестр]
 +
  
 
=== Внутриблочные переменные ===
 
=== Внутриблочные переменные ===
Строка 219: Строка 288:
  
 
В последнем случае происходит '''''автоопределение''''' типов.
 
В последнем случае происходит '''''автоопределение''''' типов.
 +
 +
 +
'''Source(s):'''  [http://downloadranking.com  Основы программирования — Осенний семестр]
 +
  
 
== Основные типы ==
 
== Основные типы ==
Строка 239: Строка 312:
 
* ''Логический''
 
* ''Логический''
 
:'''<tt>boolean</tt>''' (1) ['''<tt>''True''</tt>''' '''<tt>''False''</tt>''']
 
:'''<tt>boolean</tt>''' (1) ['''<tt>''True''</tt>''' '''<tt>''False''</tt>''']
 +
 +
 +
'''Source(s):'''  [http://downloadranking.com  Основы программирования — Осенний семестр]

Версия 18:23, 27 октября 2013

К основной странице курса


Source(s): Основы программирования — Осенний семестр


Алгоритм

Алгоритм — набор команд, определяющих порядок действий для решения поставленной задачи.

С алгоритмом всегда связан исполнитель алгоритма - устройство, имеющее систему команд.

В частности, процессор компьютера выступает исполнителем машинных команд.


Source(s): Основы программирования — Осенний семестр


Свойства алгоритма

  • Дискретность — алгоритм представляет собой последовательность элементарных шагов (команд исполнителя).
  • Детерминированность (определённость) — при одних и тех же входных данных получается один и тот же результат.
  • Завершаемость (конечность) — каждый алгоритм завершается за конечное число шагов при любом наборе исходных данных.
  • Результативность — после выполнения алгоритма известно, что считать результатом.
  • Массовость — применимость алгоритма ко множеству исходных данных.

Пример алгоритма.

Дано: x, y, z.
Найти max

Алгоритм 1. (словесное описание)

Если x>y и x>z, то максимум — это x
Если y>x и y>z, то максимум — это y
Если z>x и z>y, то максимум — это z

Алгоритм 2. (псевдокод)

max := x
Если y<max то max := y
Если z<max то max := z

Эквивалентными называются алгоритмы, имеющие одинаковые наборы исходных данных и выдающие одинаковый результат при одинаковых исходных данных. Алгоритмы 1 и 2 являются эквивалентными. Однако, они отличаются по скорости выполнения и по читаемости.


Спецификация задачи — точное, однозначное описание задачи. Включает формулировку входных и выходных данных.


Source(s): Основы программирования — Осенний семестр


Способы описания алгоритмов

1. Словесный

2. Псевдокод

3. Блок-схемы

Пример. А.2., представленный блок-схемой.

Max flowchart.png

4. Язык программирования (ЯП)

Для языка программирования команды алгоритма называются операторами или инструкциями.


Source(s): Основы программирования — Осенний семестр


Основные характеристики алгоритма

  • правильность работы
  • скорость выполнения
  • объем занимаемой памяти
  • сложность написания
  • возможность распараллеливания


Source(s): Основы программирования — Осенний семестр


Основные характеристики программы

Те же, что и у алгоритма, а также:

  • понятность при чтении
  • модифицируемость (легкость изменения кода)
  • масштабируемость (возможность изменения кода для решения родственной или более общей задачи)
  • безопасность

Если два алгоритма эквивалентны, то какой из них лучше? Тот же вопрос можно задать о программах, реализующих эти алгоритмы. Как правило, не существует однозначного ответа на этот вопрос. Лучшие по скорости алгоритмы как правило более сложны, труднее для понимания и могут требовать больше памяти. Часто для решения задачи не нужна самая быстрая программа - достаточно простой и понятной программы.


Source(s): Основы программирования — Осенний семестр


Обзор современных языков программирования

(самостоятельно на форуме)


Source(s): Основы программирования — Осенний семестр


Язык программирования PascalABC.NET

Правила записи программ на PascalABC.NET

Шпаргалка


Source(s): Основы программирования — Осенний семестр


Пример программы, вычисляющей длину и площадь круга

program First; // заголовок программы – необязательная строка
{ Программа вычисления длины окружности и площади круга 
  Автор: Михалкович С.С. Дата написания: 2.09.08 }
const Pi = 3.14;
var
  r: real;   // входные данные - радиус круга
  S,C: real; (* выходные данные - площадь круга и длина окружности *)
begin
  write('Введите радиус окружности: ');
  readln(r);
  S := Pi*r*r;
  C := 2*Pi*r;
  writeln('Длина окружности равна ',С);
  writeln('Площадь круга равна ',S);
end.


Source(s): Основы программирования — Осенний семестр


Структура программы на языке Паскаль

Заголовок программы
Раздел описаний (описываются все используемые в программе переменные и определяются их типы)
begin
  операторы (разделяются ;)
end.

Как правило, программа начинается с ввода исходных данных, после чего следуют вычисления и вывод результатов. Ввод сопровождается приглашением к вводу.


Source(s): Основы программирования — Осенний семестр


Система программирования PascalABC.NET

Как скачать, инсталлировать. (сайт системы программирования PascalABC.NET)

Общая характеристика PascalABC.NET.

Отличия языка PascalABC.NET от обычного языка Паскаль.


Source(s): Основы программирования — Осенний семестр


Компиляторы и интерпретаторы

Схема компиляции в машинный код

Схема компиляции в промежуточный код. JIT-компиляция

Ошибки времени компиляции (синтаксические и семантические) и ошибки времени выполнения

Синтаксис - правила записи конструкций, семантика - смысл конструкций.


Source(s): Основы программирования — Осенний семестр


Синтаксис и семантика ЯП

// В программе 2013-14 гг. этот пункт будет сокращен и размыт по следующим темам когда будут вводиться основные операторы языка.


Source(s): Основы программирования — Осенний семестр


Определения

Синтаксис — формальные правила описания конструкций ЯП.

Семантика — описывает смысл конструкций ЯП, а также задает ряд ограничений.


Source(s): Основы программирования — Осенний семестр


Способы описания синтаксиса

  • БНФ (Бэкуса-Наура формы, 1960, Алгол-60).

Примеры.

<цифра> ::= 0|1|2|3|4|5|6|7|8|9
<идентификатор> ::= <буква> | <идентификатор><буква> | <идентификатор><цифра>
<список идентификаторов> ::= <идентификатор> | <идентификатор> , <список идентификаторов>

0, 1, ... 9

называют терминалами (лексемами) — это "конечные символы", т.е. по умолчанию известные в ЯП.

<цифра>

так называемый нетерминал (нетерминальный символ).
Он определяется через терминалы, другие нетерминалы и самого себя. Причем в последнем случае правило задания нетерминала называется рекурсивным (как определение нетерминала <идентификатор>)
  • РБНФ (Расширенные БНФ)
[] — 0 или 1 повторение.
{} — 0 и более повторений

Пример.

<идентификатор> ::= <буква> {<буква> | <цифра>}
  • Синтаксические диаграммы (Вирт, Паскаль)

Грамматика языка — совокупность всех синтаксических правил данного ЯП, обычно заданных в форме БНФ.

Грамматика не учитывает все виды ошибок, в ЯП формулируются дополнительные семантические правила.

Замечание 1. Способы 1-3 эквивалентны.

Замечание 2. Синтаксис определяет лексемы языка.


Source(s): Основы программирования — Осенний семестр


Лексемы Паскаля

  1. спецсимволы: := += *
  2. ключевые слова (begin, end, if, for)
  3. идентификаторы (a, b1)
  4. константы (2, 'ABC', #5)
  5. комментарии (3 вида)
{...}
(*...*)
//...


Source(s): Основы программирования — Осенний семестр


Переменные и их описание

Основные сведения

Переменная — это ячейка памяти компьютера, имеющая имя и тип.

Тип определяет размер переменной и множество принимаемых ею значений.

В языке Pascal любая переменная перед использованием должна быть описана.
Обычно переменные описываются в разделе описаний.

<xh4> Синтаксис в виде РБНФ </xh4>

<программа> ::= [program <имя>;] 
               <раздел описаний> 
               begin
                 <операторы>
               end.
<операторы> ::= <оператор>{; <оператор>}
<раздел описаний> ::= {<секция раздела описаний>}
<секция раздела описаний> ::= <секция описания переменных> | <с.о. констант> | <с.о. типов> | <с.о. подпрограмм>...

Пример секции описания переменных.

var
  a,b: real;
  i: integer;
<секция описания переменных> ::= var<подсекция>{< подсекция>}
<подсекция> ::= <список имен>: <тип>;
<список имен> ::= <имя>{,<имя>}
<тип> ::= <имя>


Source(s): Основы программирования — Осенний семестр


Внутриблочные переменные

В PascalABC.NET возможно внутриблочное описание переменных:

begin
  var i,j: integer;
  var r: real := 5.2;
  var Pi := 3.14;

В последнем случае происходит автоопределение типов.


Source(s): Основы программирования — Осенний семестр


Основные типы

  • Целые
integer (4 байта)
int64 (8)
byte (1)
  • Вещественные
real (8)
  • Символьные
char (2 байта — Unicode)
  • Строковые
string
string[200]
shortstring = string[255]
  • Логический
boolean (1) [True False]


Source(s): Основы программирования — Осенний семестр