Синтаксический распознаватель арифметического оператора условного перехода языка FORTRAN
Министерство
науки,
высшей школы
и технической
политики Российской
Федерации.
Новосибирский
Государственный
Технический
Университет.
Курсовая
работа по системному
программированию.
Синтаксический
распознаватель
арифметического
оператора
условного
перехода языка
FORTRAN.
Факультет:
АВТ.
Кафедра:
АСУ.
Группа:
А–513.
Студент:
Бойко Константин
Анатольевич.
Преподаватель:
Шорников Юрий
Владимирович.
Ассистент: Панова
Вера Борисовна.
Дата:
30 апреля 1997 г.
Отметка
о защите:
Новосибирск.
Язык
оператора.
Язык
арифметического
оператора
условного
перехода языка
FORTRAN.
IF(<АВ>)
LABEL1,LABEL2,LABEL3
АВ
- Арифметическое
Выражение.
LABEL1,LABEL2,LABEL3
- первая,
вторая
и третья метки
соответственно.
Грамматика
языка.
G[<Оператор>]:
<Оператор>
®
IF(<АВ>)
®
<ЦБЗ>
<АВ> ®
T | <АВ>+T
| <АВ>-T
T ®
O | T*O | T/O | T**O
O ®
(<АВ>) | <Идентификатор>
| <ЧПЗ>
<Идентификатор>
®
Б{Б|Ц}
<ЦБЗ> ®
Ц{Ц}[L]
<ЧПЗ> ®
Ц{Ц}[.Ц{Ц}]
Условные
обозначения:
Т
–
ТЕРМ.
О
–
ОПЕРАНД.
Б
–
БУКВА.
Ц
–
ЦИФРА.
ЦБЗ
–
ЦЕЛОЕ
БЕЗ ЗНАКА.
**
–
ВОЗВЕДЕНИЕ
В СТЕПЕНЬ.
LABEL
–
МЕТКА.
ЧПЗ
–
ЧИСЛО
С ПЛАВАЮЩЕЙ
ЗАПЯТОЙ.
L
–
КОНЕЦ
СТРОКИ (пусто).
АВ
–
АРИФМЕТИЧЕСКОЕ
ВЫРАЖЕНИЕ.
Классификация
грамматики.
Данная грамматика
G[<ОПЕРАТОР>],
согласно
классификации
Хомского, является
контекстно-свободной,
так как правая
часть каждой
редукции начинается
либо с терминального
символа, либо
с нетерминального,
принадлежащего
объединённому
словарю.
A
®
a, AОVn,
aОV*.
Грамматика
G[<ОПЕРАТОР>]
не является
автоматной,
так как не все
её редукции
начинаются
с терминального
символа. По
этой же причине
данная грамматика
не является
S
-
грамматикой.
Метод
анализа.
Для данной
грамматики
реализован
разбор методом
рекурсивного
спуска, поскольку
она относится
к классу
контекстно-свободных.
Идея метода
состоит в том,
что каждому
нетерминальному
символу ставится
в соответствие
определённая
программная
единица (функция),
которая распознаёт
цепочку, порождаемую
этим нетерминалом.
Эти процедуры
и функции вызываются
в соответствии
с правилами
грамматики
и иногда вызывают
сами себя.
Данный метод
реализован
на языке C++,
поскольку он
обладает рекурсивными
возможностями.
Диагностика
и нейтрализация
ошибок.
Для данной
грамматики
производится
только диагностика
и нейтрализация
ошибок. Исправление
ошибок не
производится.
Нейтрализация
ошибок осуществляется
по методу Айронса,
то есть, спускаясь
по синтаксическому
дереву без
возврата по
контексту, при
обнаружении
тупиковой
ситуации
отбрасываются
те литеры (символы),
которые привели
в тупиковую
ситуацию и
разбор продолжается.
Тестирование.
ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
IF(((6/t+g*456)/(9.347*y-555))**6)
64,44,548
ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
Текущий
символ ( - 40.
AB - Проверка
на Арифметическое
Выражение.
Текущий
символ ( - 40.
Term - Проверка
на Терм.
Operand -
Проверка на
Операнд.
AB - Проверка
на Арифметическое
Выражение.
Текущий
символ ( - 40.
Term - Проверка
на Терм.
Operand -
Проверка на
Операнд.
AB - Проверка
на Арифметическое
Выражение.
Текущий
символ 6 - 54.
Term - Проверка
на Терм.
Operand -
Проверка на
Операнд.
IDENT -
Проверка на
Идентификатор
с символа 6.
FLOAT -
проверка на
число с плавающей
запятой с цифры
6.
Текущий
символ / - 47.
Текущий
символ t - 116.
Term - Проверка
на Терм.
Operand -
Проверка на
Операнд.
IDENT -
Проверка на
Идентификатор
с символа t.
Текущий
символ + - 43.
AB - Проверка
на Арифметическое
Выражение.
Текущий
символ g - 103.
Term - Проверка
на Терм.
Operand -
Проверка на
Операнд.
IDENT -
Проверка на
Идентификатор
с символа g.
Текущий
символ * - 42.
Текущий
символ 4 - 52.
Term - Проверка
на Терм.
Operand -
Проверка на
Операнд.
IDENT -
Проверка на
Идентификатор
с символа 4.
FLOAT -
проверка на
число с плавающей
запятой с цифры
4.
Текущий
символ 5 - 53.
Текущий
символ 6 - 54.
Текущий
символ ) - 41.
Текущий
символ / - 47.
Текущий
символ ( - 40.
Term - Проверка
на Терм.
Operand -
Проверка на
Операнд.
AB - Проверка
на Арифметическое
Выражение.
Текущий
символ 9 - 57.
Term - Проверка
на Терм.
Operand -
Проверка на
Операнд.
IDENT -
Проверка на
Идентификатор
с символа 9.
FLOAT -
проверка на
число с плавающей
запятой с цифры
9.
Текущий
символ . - 46.
Текущий
символ 3 - 51.
Текущий
символ 4 - 52.
Текущий
символ 7 - 55.
Текущий
символ * - 42.
Текущий
символ y - 121.
Term - Проверка
на Терм.
Operand -
Проверка на
Операнд.
IDENT -
Проверка на
Идентификатор
с символа y.
Текущий
символ - - 45.
AB - Проверка
на Арифметическое
Выражение.
Текущий
символ 5 - 53.
Term - Проверка
на Терм.
Operand -
Проверка на
Операнд.
IDENT -
Проверка на
Идентификатор
с символа 5.
FLOAT -
проверка на
число с плавающей
запятой с цифры
5.
Текущий
символ 5 - 53.
Текущий
символ 5 - 53.
Текущий
символ ) - 41.
Текущий
символ ) - 41.
Текущий
символ * - 42.
Текущий
символ * - 42.
Текущий
символ 6 - 54.
Term - Проверка
на Терм.
Operand -
Проверка на
Операнд.
IDENT -
Проверка на
Идентификатор
с символа 6.
FLOAT -
проверка на
число с плавающей
запятой с цифры
6.
Текущий
символ ) - 41.
Текущий
символ - 32.
Текущий
символ 6 - 54.
ABS - проверка
на Целое Без
Знака с цифры
6.
Текущий
символ 4 - 52.
Текущий
символ , - 44.
Текущий
символ 4 - 52.
ABS - проверка
на Целое Без
Знака с цифры
4.
Текущий
символ 4 - 52.
Текущий
символ , - 44.
Текущий
символ 5 - 53.
ABS - проверка
на Целое Без
Знака с цифры
5.
Текущий
символ 4 - 52.
Текущий
символ 8 - 56.
Текущий
символ NULL
- 0.
ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
IF(r**34/50.22)
3,56,1
ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
Текущий
символ ( - 40.
AB - Проверка
на Арифметическое
Выражение.
Текущий
символ r - 114.
Term - Проверка
на Терм.
Operand -
Проверка на
Операнд.
IDENT -
Проверка на
Идентификатор
с символа r.
Текущий
символ * - 42.
Текущий
символ * - 42.
Текущий
символ 3 - 51.
Term - Проверка
на Терм.
Operand -
Проверка на
Операнд.
IDENT -
Проверка на
Идентификатор
с символа 3.
FLOAT -
проверка на
число с плавающей
запятой с цифры
3.
Текущий
символ 4 - 52.
Текущий
символ / - 47.
Текущий
символ 5 - 53.
Term - Проверка
на Терм.
Operand -
Проверка на
Операнд.
IDENT -
Проверка на
Идентификатор
с символа 5.
FLOAT -
проверка на
число с плавающей
запятой с цифры
5.
Текущий
символ 0 - 48.
Текущий
символ . - 46.
Текущий
символ 2 - 50.
Текущий
символ 2 - 50.
Текущий
символ ) - 41.
Текущий
символ - 32.
Текущий
символ 3 - 51.
ABS - проверка
на Целое Без
Знака с цифры
3.
Текущий
символ , - 44.
Текущий
символ 5 - 53.
ABS - проверка
на Целое Без
Знака с цифры
5.
Текущий
символ 6 - 54.
Текущий
символ , - 44.
Текущий
символ 1 - 49.
ABS - проверка
на Целое Без
Знака с цифры
1.
Текущий
символ NULL - 0.
ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
Листинг
программы.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// FILE
"KURSOVIC.CPP".
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// ВАРИАHТ
# 2.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// Арифметический
оператор условного
перехода языка
FORTRAN.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// Кафедpа :
АСУ.
// Гpуппа :
А-513.
// Студент :
Бойко Константин
Анатольевич.
//
Пpеподаватели
: кандидат
технических
наук, доцент Шоpников
Юpий Владимиpович,
// ассистент Панова
Веpа Боpисовна.
// Дата :
30 апреля 1997г.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
//
Заголовочные
файлы.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
#
include
#
include
#
include
#
include
# include
"keyboard.h"
#
include
# include
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// Константы.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
#
define FILE_NAME "TEXT.TXT"
#
define YES 1
# define NO 2
# define OK 3
//# define TEST
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// Глобальные
переменные.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
char
file1[22][60]; // Массив строк.
char
mes[22][30][50]; // Массив
сообщений об
ошибках.
char
bufer[4096]; // Снимок с
экрана.
int
com=0; // Показатель
: откомпилирован
файл или нет.
int
pos=2; // Текущая позиция
в строке.
char
string[80]; // Текущая
строка файла.
char nx; //
Текущий символ
в строке.
int e1=0; //
Счетчик страниц
массива собщений
об ошибках.
int e2=0; //
Счетчик строк
в странице.
int l=0; //
Счетчик меток.
FILE*
fl=fopen("MESSAGE.TXT","wt"); // Файл
с сообщениями
об ошибках.
MyPuts("
~F1~ Help ~F2~ Grammar ~F3~ Language ~F4~ Compile ~ESC~ Exit",
LIGHTBLUE);
}
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// MyPuts.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
void
MyPuts(char* string,int color)
{
int j=0;
for(int
i=0;string[i] != NULL;i++)
{
if(string[i]=='~'
&& j==0)
{
textcolor(color);
i++;
j++;
}
if(string[i]=='~'
&& j!=0)
{
textcolor(BLACK);
i++;
j--;
}
cprintf("%c",string[i]);
if(string[i]==NULL)
break;
}
}
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// Функция
вывода файла
на экран.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
void
Print_File(void)
{
window(3,2,77,24);
textattr(31);
for(int
i=0;i<22;i++)
{
cputs(file1[i]);
putch('r');
}
}
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// Меню.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
void Menu(void)
{
gettext(1,1,80,25,bufer); //
Вся информация
с экрана заносится
в буфер.
int y=1; //
Счетчик строк.
gotoxy(1,1);
textattr(63);
clreol();
cputs(file1[0]);
textattr(31);
gotoxy(5,23);
cprintf("
%-2d ",y);
while(1)
{
switch
(i_readkey())
{
case
EASC_F1:
gettext(1,1,80,25,bufer);
Help();
puttext(1,1,80,25,bufer);
break;
case
EASC_F2:
gettext(1,1,80,25,bufer);
Grammar();
puttext(1,1,80,25,bufer);
break;
case
EASC_F3:
gettext(1,1,80,25,bufer);
Language();
puttext(1,1,80,25,bufer);
break;
case
EASC_F4:
gettext(1,1,80,25,bufer);
Compile();
puttext(1,1,80,25,bufer);
window(48,2,78,23);
textattr(95);
clrscr();
Windows(49,3,79,24,"Message");
Message(y-1);
break;
case
EASC_Esc:
window(1,1,80,25);
textattr(7);
clrscr();
fcloseall();
exit(1);
break;
case
EASC_Up:
if(y>1)
{
if(com>0)
window(3,2,47,24);
else
window(3,2,77,24);
y--;
gotoxy(1,y);
textattr(63);
clreol();
cputs(file1[y-1]);
gotoxy(1,y+1);
textattr(31);
clreol();
cputs(file1[y]);
gotoxy(5,23);
cprintf("
%d ",y);
if(com>0)
Message(y-1);
}
break;
case
EASC_Down:
if(y<22)
{
if(com>0)
window(3,2,47,24);
else
window(3,2,77,24);
gotoxy(1,++y);
textattr(63);
clreol();
cputs(file1[y-1]);
gotoxy(1,y-1);
textattr(31);
clreol();
cputs(file1[y-2]);
gotoxy(5,23);
cprintf("
%d ",y);
if(com>0)
Message(y-1);
}
break;
}
}
}
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// Help.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
void Help(void)
{
window(1,1,80,25);
textattr(78);
clrscr();
Windows(1,1,80,25,"Help");
window(4,3,77,23);
cprintf("НОВОСИБИРСКИЙ
ГОСУДАРСТВЕННЫЙ
ТЕХНИЧЕСКИЙ
УНИВЕРСИТЕТnnr");
cprintf(" КАФЕДРА
АСУnnr");
cprintf(" Курсовая
работа по системному
программированию
на тему:nr");
cprintf("
"Арифметический
оператор условного
перехода языка
FORTRAN".nnr");
cprintf("
Студента группы
А-513nnr");
cprintf("
Бойко Константина
Анатольевича.nnr");
cprintf("В
программе
использованы
клавиши:nr");
cprintf("
F1 - данный Help.nr");
cprintf("
F2 - грамматика
языка.nr");
cprintf("
F3 - язык оператора.nr");
cprintf("
F4 - компиляция
файла.nr");
cprintf("
ESC - выход из
программы.nnr");
cprintf("
Для выхода из
Help нажмите любую
клавишу.");
getch();
}
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// Грамматика.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
void
Grammar(void)
{
window(10,2,70,23);
textattr(46);
clrscr();
Windows(10,2,70,23,"Grammar");
window(12,4,68,22);
cprintf("
1. <Оператор>
-> IF(<АВ>),,nr");
cprintf("
2. -> <ЦБЗ>nr");
cprintf("
3. <АВ> -> T | <АВ>+T |
<АВ>-Tnr");
cprintf("
4. T -> O | T*O | T/O | T**Onr");
cprintf("
5. O -> (<АВ>) | <Идентификатор>
| <ЧПЗ>nr");
cprintf("
6. <Идентификатор>
-> Б{Б|Ц}nr");
cprintf("
7. <ЦБЗ> -> Ц{Ц}nr");
cprintf("
8. <ЧПЗ> -> Ц{Ц}[.Ц{Ц}]nnr");
cprintf("
Условные
обозначения:nr");
cprintf(" T
- терм.nr");
cprintf(" O
- операнд.nr");
cprintf(" Б
- буква.nr");
cprintf(" Ц
- цифра.nr");
cprintf(" ЦБЗ -
целое без
знака.nr");
cprintf(" ЧПЗ -
число с плавающей
запятой.nr");
cprintf(" **
- возведение
в степень.nr");
cprintf("
- метка.nr");
cprintf(" <АВ> -
арифметическое
выражение.");
getch();
}
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// Язык.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
void
Language(void)
{
window(20,7,60,17);
textattr(62);
clrscr();
Windows(20,7,60,17,"Language");
window(22,9,58,16);
cprintf(" IF(<АВ>)
LABEL1,LABEL2,LABEL3nnr");
cprintf("
АВ - Арифметическое
Выражение.nr");
cprintf("
LABEL1,LABEL2,LABEL3 - первая,вторая
и третья метки
соответственно.nr");
getch();
}
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// Компиляция
программы.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
void
Compile(void)
{
window(20,7,55,13);
textattr(94);
clrscr();
Windows(20,7,55,13,"Compile");
window(22,8,58,16);
gotoxy(1,1);
if(com!=0)
{
cprintf("nn
Файл откомпилирован!");
Beep(900,1000);
return;
}
cputs("n Идет
компиляция
файла.rnn Пожалуйста,
подождите...");
#ifdef TEST
window(1,1,80,25);
clrscr();
#endif
for(int
i=0;file1[i][0]!=NULL;i++)
{
Operator(file1[i]);
if(l!=3 &&
l!=0)
Error(11);
e1++;
e2=0;
}
com++;
delay(300);
Beep(1000,200);
}
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// Оператор.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
void
Operator(char* str)
{
pos=2;
l=0;
string[0]=NULL;
strcpy(string,str);
string[strlen(string)-1]=NULL;
char temp[3];
temp[0]=str[0];
temp[1]=str[1];
temp[2]=NULL;
#ifdef TEST
puts(string);
puts(temp);
getch();
#endif
fprintf(fl,"
ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕn");
fprintf(fl,"%sn",string);
if(strcmp(temp,"IF")!=0)
{
#ifdef TEST
printf("Не
найден оператор
IF.n");
#endif
Error(10);
return;
}
Scan();
if(nx==' ')
Scan();
if(nx!='(')
Error(7);
if(nx==NULL)
{
Error(12);
Error(9);
return;
}
AB();
while(nx!=')'
&& nx!=NULL && nx!=' ')
Scan();
if(nx!=')')
Error(3);
if(nx==NULL)
{
Error(9);
return;
}
Scan();
if(nx==NULL)
{
Error(9);
return;
}
if(nx==' ')
Scan();
Label();
if(nx!=',')
{
Error(5);
Scan();
}
else
Scan();
if(nx==NULL)
return;
Label();
if(nx!=',')
{
Error(5);
Scan();
}
else
Scan();
if(nx==NULL)
return;
Label();
if(nx!=NULL)
{
Error(6);
Scan();
}
return;
}
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// Scan.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
void Scan(void)
{
nx=string[pos++];
#ifdef TEST
printf("Текущий
символ %c - %d.n",nx,nx);
#endif
fprintf(fl,"Текущий
символ %c - %d.n",nx,nx);
}
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// Метка.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
void
Label(void)
{
if(ABS() ==
NO)
{
Error(8);
Scan();
}
else
l++;
}
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// Целое
Без Знака.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
int ABS(void)
{
#ifdef TEST
cprintf("ABS
- проверка на
Целое Без Знака
с цифры %c.rn",nx);
#endif
fprintf(fl,"ABS
- проверка на
Целое Без Знака
с цифры %c.n",nx);
if(isdigit(nx))
{
while(isdigit(nx))
Scan();
return(YES);
}
return(NO);
}
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
//
Арифметическое
Выражение.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
int AB(void)
{
#ifdef TEST
cprintf("AB
- Проверка на
Арифметическое
Выражение.rn");
#endif
fprintf(fl,"AB
- Проверка на
Арифметическое
Выражение.n");
Scan();
if(nx==')')
{
Error(12);
return(NO);
}
Term();
if(nx=='+')
{
AB();
}
else
if(nx=='-')
{
AB();
}
if(nx==NULL)
return(OK);
else
if(nx!='*' && nx!='/' && nx!=')')
Error(1);
return(YES);
}
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// Терм.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
int Term(void)
{
#ifdef TEST
cprintf("Term
- Проверка на
Терм.rn");
#endif
fprintf(fl,"Term
- Проверка на
Терм.n");
Operand();
if(nx=='/')
{
Scan();
Term();
}
else
if(nx=='*')
{
Scan();
if(nx=='*')
{
Scan();
Term();
}
else Term();
}
if(nx==NULL)
return(OK);
else
if(nx!='+' && nx!='-' && nx!=')')
Error(2);
return(OK);
}
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// Операнд.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
int
Operand(void)
{
#ifdef TEST
cprintf("Operand
- Проверка на
Операнд.rn");
#endif
fprintf(fl,"Operand
- Проверка на
Операнд.n");
if(nx=='(')
{
AB();
if(nx!=')')
Error(3);
else
{
Scan();
return(OK);
}
}
else if(IDENT()
== NO)
{
if(Float() ==
NO)
Error(4);
}
return(OK);
}
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
//
Идентификатор.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
int IDENT(void)
{
#ifdef TEST
cprintf("IDENT
- Проверка на
Идентификатор
с символа
%c.rn",nx);
#endif
fprintf(fl,"IDENT
- Проверка на
Идентификатор
с символа %c.n",nx);
if(isalpha(nx))
{
while(isalpha(nx)
|| isdigit(nx))
Scan();
return(YES);
}
return(NO);
}
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// Ошибки.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
void Error(int
num)
{
char *E[]={
"Ожидается
'+' или '-'.",
"Ожидается
'*','/' или '**'.",
"Ожидается
).",
"Ожидается
идентификатор
или целое без
знака.",
"Отсутствует
','.",
"Не
конец строки.",
"Ожидается
(.",
"Метка
- не целое без
знака.",
"Отсутствуют
метки.",
"Не
найден оператор
IF.",
"Отсутствует
метка.",
"Отсутствует
AB.",
NULL
};
sprintf(mes[e1][e2],"%s",E[num-1]);
e2++;
#ifdef TEST
Beep(1000,100);
cprintf("Ошибка:
%srn",E[num-1]);
getch();
#endif
fprintf(fl,"
ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕn");
fprintf(fl,"Ошибка:
%srn",E[num-1]);
}
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// Float.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
int Float(void)
{
#ifdef TEST
cprintf("FLOAT
- проверка на
число с плавающей
запятой с цифры
%c.rn",nx);
#endif
fprintf(fl,"FLOAT
- проверка на
число с плавающей
запятой с цифры
%c.n",nx);
if(isdigit(nx))
{
while(isdigit(nx))
Scan();
if(nx=='.')
{
Scan();
while(isdigit(nx))
Scan();
}
return(YES);
}
return(NO);
}
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
// Message.
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
void
Message(int x)
{
window(50,3,76,22);
textattr(95);
clrscr();
gotoxy(1,1);
for(int
i=0;mes[x][i][0]!=NULL;i++)
cprintf("%srn",mes[x][i]);
}
//ѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕѕ
Литература.
Курс
лекций по системному
программированию.
Герберт
Шилдт «C
для профессиональных
программистов».
Если Вам нужна помощь с академической работой (курсовая, контрольная, диплом, реферат и т.д.),
обратитесь к нашим специалистам. Более 90000 специалистов готовы Вам помочь.
Бесплатные корректировки и доработки. Бесплатная оценка стоимости работы.
Министерство Образования Республики Беларусь Белорусский Государственный Университет Информатики и Радиоэлектроники Кафедра ЭВМ Отчёт по учебной практике
Си - это язык программирования общего назначения. Постановка задачи: разработка программы - калькулятора. Метод решения задачи. Алгоритм работы программы. Технические данные для использования. Описание основных функций.
Составление процедур манипулирования, обеспечивающих формирование и ввод целых чисел произвольной длины, сложение, вычитание, сравнение и умножение целых чисел.
Постановка задачи. Метод решения задачи. Описание логического представления данных. Схема данных. Структура программы. Спецификация на функциональные модули. Технические требования для использования. Руководство пользователя.
Програмна робота з графами: операції їх зчитування, збереження та обробки у вигляді перевірки на симетричність та орієнтованість. Основи пошуку в графі в різних напрямках. Розбиття множини вершин на класи еквівалентності за відношенням зв'язності графу.
Введение Разработка системного программного обеспечения -это прямая задача системного программиста. Более того разработка не есть конечный пункт его деятельности. Совершенное владение этим инструментом -вот главная задача. Системное программирование является одной и наиболее широкой областью прогр...
Министерство науки, высшей школы и технической политики Российской Федерации. Новосибирский Государственный Технический Университет. Курсовая работа по системному программированию.
Министерство науки, высшей школы и технической политики Российской Федерации. Новосибирский Государственный Технический Университет. Курсовая работа по системному программированию.
Вот довольно реалистичный пример класса string. В нем производится учет ссылок на строку с целью минимизировать копирование и в качестве констант применяются стандартные символьные строки C++.
Целью работы является демонстрация работы с динамической памятью. Динамическое распределение памяти предоставляет программисту большие возможности при обращении к ресурсам памяти в процессе выполнения программы.
Элементарная работа со строками, создание и открытие файлов, работа со строками с помощью указателей. Непосредственное использование указателей для нахождения нужной информации в память. Как найти самое длинное общее слово двух заданных предложений.
Постановка задачи. Метод решения задачи. Описание логического представления данных. Схема данных. Структура программы. Спецификация на функциональные модули. Технические требования для использования.