Форум программистов, компьютерный форум, киберфорум
Наши страницы

Перевести из Pascal в C++ - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Перечислить слова (работа со строками) http://www.cyberforum.ru/cpp-beginners/thread217215.html
Пожалуйста, напишите программу на С, по следующей задаче: Перечислить все слова заданного предложения, которые состоят из тех же букв , что и первое слово предложения и заканчиваются на такую же...
C++ Динамическая структура Составить программу, которая содержит динамическую информацию о наличии автобусов в автобусном парке. Сведения о каждом автобусе включают: · номер автобуса; · фамилию и инициалы водителя; · номер... http://www.cyberforum.ru/cpp-beginners/thread217213.html
Переделать из Delphi в С++ C++
Вобщем есть программа поиска подстроки в строке с помощью конечных автоматов реализованная на Delphi. Нужно ее перекомпилировать в C++. Заранее благодарен. Вот код: {$o-,q+,r+} {$apptype...
C++ класс треугольник
добрый вечер) мне нужно было создать класс треугольник и реализовать операции нахождения площади, периметра, я сделала это на примере класса прямоугольник, где бралось 2 стороны(a ,b.. и вот у...
C++ Найти скалярное произведение двух n-мерных векторов http://www.cyberforum.ru/cpp-beginners/thread217174.html
У меня вообще не понимаю. И ничего не получился! Задача СИ : Написать программу, которая находит скалярное произведение двух n-мерных векторов. Указание. Скалярное произведение определяется по...
C++ в матрице, строку где все числа четные, расположить в обратном порядке. дана матрица целых чисел. строки, где все элементы четные, расположить в обратном порядке. помогите студенту получить зачет. 1 лаба осталась. подробнее

Показать сообщение отдельно
ZelenyiZmei
11 / 10 / 0
Регистрация: 06.10.2008
Сообщений: 104

Перевести из Pascal в C++ - C++

22.12.2010, 00:00. Просмотров 459. Ответов 0
Метки (Все метки)

Доброй ночи знатоки Си, пожалуйста помогите, перевидите это на язык Си++
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
unit LexElem;
 
interface
{ Модуль, описывающий структуру элементов таблицы лексем }
 
uses Classes, TblElem, LexType;
 
type
 
{ Структура для информации о лексемах }
TLexInfo = record
  case LexType: TLexType of
    LEX_VAR: (VarInfo: TVarInfo);
    LEX_CONST: (ConstVal: integer);
    LEX_START: (szInfo: PChar);
end;
 
{ Структура для описания лексемы }
TLexem = class(TObject)
 protected
  { Информация о лексеме }
  LexInfo: TLexInfo;
  { Позиция лексемы в исходном тексте программы }
  iStr,iPos,iAllP: integer;
 public
  { Конструкторы для создания лексем разных типов}
  constructor CreateKey(LexKey: TLexType;
                        iA,iSt,iP: integer);
  constructor CreateVar(VarInf: TVarInfo;
                        iA,iSt,iP: integer);
  constructor CreateConst(iVal: integer;
                          iA,iSt,iP: integer);
  constructor CreateInfo(sInf: string;
                         iA,iSt,iP: integer);
  destructor Destroy; override;
  { Свойства для получения информации о лексеме }
  property LexType: TLexType read LexInfo.LexType;
  property VarInfo: TVarInfo read LexInfo.VarInfo;
  property ConstVal: integer read LexInfo.ConstVal;
  { Свойства для чтения позиции лексемы
    в исходном тексте программы }
  property StrNum: integer read iStr;
  property PosNum: integer read iPos;
  property PosAll: integer read iAllP;
  { Текстовая информация о типе лексемы }
  function LexInfoStr: string;
  { Имя для лексемы-переменной }
  function VarName: string;
end;
 
{ Структура для описания списка лексем }
TLexList = class(TList)
 public
  { Деструктор для освобождения памяти
    при уничтожении списка }
  destructor Destroy; override;
  { Процедура очистки списка }
  procedure Clear; override;
  { Процедура и свойство для получения информации
    о лексеме по ее номеру }
  function GetLexem(iIdx: integer): TLexem;
  property Lexem[iIdx: integer]: TLexem read GetLexem;
           default;
end;
 
implementation
 
uses SysUtils, LexAuto;
 
constructor TLexem.CreateKey(LexKey: TLexType;
                             iA,iSt,iP: integer);
{ Конструктор создания лексемы типа "ключевое слово" }
begin
  inherited Create;
  LexInfo.LexType := LexKey;
  { запоминаем тип ключевого слова }
  iStr := iSt; { запоминаем позицию лексемы }
  iPos := iP;
  iAllP := iA;
end;
 
constructor TLexem.CreateVar(VarInf: TVarInfo;
                             iA,iSt,iP: integer);
{ Конструктор создания лексемы типа "ключевое слово" }
begin
  inherited Create;
  LexInfo.LexType := LEX_VAR; { тип - "переменная" }
  { запоминаем ссылку на таблицу идентификаторов }
  LexInfo.VarInfo := VarInf;
  iStr := iSt; { запоминаем позицию лексемы }
  iPos := iP;
  iAllP := iA;
end;
 
constructor TLexem.CreateConst(iVal: integer;
                               iA,iSt,iP: integer);
{ Конструктор создания лексемы типа "константа" }
begin
  inherited Create;
  LexInfo.LexType := LEX_CONST; { тип - "константа" }
  { запоминаем значение константы }
  LexInfo.ConstVal := iVal;
  iStr := iSt; { запоминаем позицию лексемы }
  iPos := iP;
  iAllP := iA;
end;
 
constructor TLexem.CreateInfo(sInf: string;
                              iA,iSt,iP: integer);
{ Конструктор создания информационной лексемы }
begin
  inherited Create;
  LexInfo.LexType := LEX_START; { тип - "доп. лексема" }
  { выделяем память для информации }
  LexInfo.szInfo :=  StrAlloc(Length(sInf)+1);
  { запоминаем информацию }
  StrPCopy(LexInfo.szInfo,sInf);
  iStr := iSt; { запоминаем позицию лексемы }
  iPos := iP;
  iAllP := iA;
end;
 
destructor TLexem.Destroy;
begin
  { Освобождаем занятую память,
    если это информационная лексема }
  if LexType = LEX_START then StrDispose(LexInfo.szInfo);
  inherited Destroy;
end;
 
function TLexem.VarName: string;
{ Функция получения имени лексемы типа "переменная" }
begin
  Result := VarInfo.VarName;
end;
 
function TLexem.LexInfoStr: string;
{ Текстовая информация о типе лексемы }
begin
  case LexType of
    LEX_VAR:   Result := VarName;
    { для переменной - ее имя  }
    LEX_CONST: Result := IntToStr(ConstVal);
    { для константы - значение }
    LEX_START: Result := StrPas(LexInfo.szInfo);
    { для инф. лексемы - информация }
    else       Result := LexTypeInfo(LexType);
    { для остальных - имя типа }
  end;
end;
 
procedure TLexList.Clear;
{ Процедура очистки списка }
var i: integer;
begin
  { Уничтожаем все элементы списка }
  for i:=Count-1 downto 0 do Lexem[i].Free;
  inherited Clear; { вызываем функцию базового класса }
end;
 
destructor TLexList.Destroy;
{ Деструктор для освобождения памяти
  при уничтожении списка }
begin
  Clear; { Уничтожаем все элементы списка }
  { Вызываем деструктор базового класса }
  inherited Destroy;
end;
 
function TLexList.GetLexem(iIdx: integer): TLexem;
{ Получение лексемы из списка по ее номеру }
begin
  Result := TLexem(Items[iIdx]);
end;
 
end.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru