Форум программистов, компьютерный форум CyberForum.ru

Переписать программу с паскаля на Си++ - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Создать динамический список, поменять местами последний и первый элементы списка, предпоследний и второй и т.д. http://www.cyberforum.ru/cpp-beginners/thread1155950.html
Всем привет. Подкиньте идею, весь мозг сломал. Задание:Создать динамический список. Поменять местами последний и первый элементы списка, предпоследний и второй и т. д.. Список создал, даже местами поменял, но поменял только заново инициализированный(созданный из массива) список, а как поменять местами заранее созданный список (добавленные, удаленные элементы) никак не соображу. Понимаю, что нужно...
C++ Удалить из строки все пробелы, расположенные перед знаком препинания Дана строка до точки, группа символов в которой между пробелами считается словом, знаки препинания от слова пробелом не отделяются. Удалить из строки все пробелы, расположенные перед знаком препинания. http://www.cyberforum.ru/cpp-beginners/thread1155945.html
C++ Криптография: расшифровать два послания
Без труда справившись с образцом тайнописи старинной дипломатии – ПАЙЦИКЕ ТСЮГ Т "КАМАЩАМЛТОЙ ЧМАРОКЕ" – КАЙПОНИЛИ, НМИРЕПЯШВЕЙЛЯ Ш МОЛЛИИ ЦСЯ ЦИНСОРАКИГЕЛТОЙ НЕМЕНИЛТИ, попробуйте вскрыть более искусный шифр – ЫЛЧУВФНУЮЕГИХВФСЗИУЙГРЛИВХИНФХГ.
C++ В алфавитном порядке расположить буквы из которых состоит текст с их количеством
Задание Составить алгоритм и программу обработки фразы (строки текста), находящемся в текстовом файле Inputtxt.txt. В результате работы программы в файле отчета необходимо в алфавитном порядке расположить буквы из которых состоит текст с их количеством. Пример: Содержание исходного файла Inputtxt.txt слово "МАМА" В результате работы программы получен файл следующего вида: Буква...
C++ Подсчитать количество предлогов - в, на, с и т.д. в тексте http://www.cyberforum.ru/cpp-beginners/thread1155870.html
Помогите с задачей, нужно считать файл с тестом и в нем подсчитать сколько раз встречается каждый предлог, если кто то может, помогите на одном примере примере. Заранее спасибо)
C++ Вычислить количество элементов массива X со значениями в интервале [A1, A2] и сформировать из них массив Y Помогите пожалуйста решить, можно и с коментариями. Задан массив Х{xi} ( ). Вычислить количество элементов массива X со значениями в интервале и сформировать из них массив Y. подробнее

Показать сообщение отдельно
IrinaCk
 Аватар для IrinaCk
0 / 0 / 0
Регистрация: 13.03.2013
Сообщений: 27
24.04.2014, 10:14     Переписать программу с паскаля на Си++
Нужно переписать программу с паскаля на си ++. а то у меня не получается...
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
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
uses crt;
label l1,l2,l3,l4,l5;
type osa=record
 x:integer;
 Y:integer;
 life:integer;
 baby:integer;
 xp:integer;
 Yp:integer;
 end;
var
a:array[0..22,0..22]of integer; //массив
b:array[0..22,0..22]of string;//массив
o1:array[0..20] of osa;//массив
o2:array[0..20] of osa;//массив
i,j,k,ch,kol1,kol2,n3,food,kk:integer;
begin
writeln('Введите колличество особей');
readln(kol1,kol2);
food:=5;
clrscr;
randomize;
 for j:=1 to 21 do
  begin
   for i:=1 to 21 do
    begin
     a[i,j]:=0;
     b[i,j]:='#';
     write(b[i,j]:2);
    end;
    writeln;
   end;
 readkey;
 
 //Особи
 for k:=1 to kol1 do
  begin
   l1:
   o1[k].x:=random(21);
   o1[k].y:=random(21);
   i:=o1[k].x;
   j:=o1[k].y;
   if  (a[i,j]=0)
    then a[i,j]:=1
    else goto l1;
   o1[k].life:=10;
   o1[k].baby:=12;
  end;
  for k:=1 to kol2 do
  begin
   l2:
   o2[k].x:=random(21);
   o2[k].y:=random(21);
   i:=o2[k].x;
   j:=o2[k].y;
   if  (a[i,j]=0)
    then a[i,j]:=2
    else goto l2;
   o2[k].life:=9;
   o2[k].baby:=8;
  end;
 
  clrscr;
 for j:=1 to 21 do
  begin
   for i:=1 to 21 do
    begin
     if a[i,j]=1
      then b[i,j]:='1';
     if a[i,j]=2
      then b[i,j]:='2';
     write(b[i,j]:2);
    end;
    writeln;
   end;
 readkey;
 //---------------------------------------
 
 for kk:=1 to 100 do begin
 
 //Смерть
 
 for k:=1 to kol1 do
 begin
 if o1[k].life=0
  then
  begin
  i:=o1[k].x;
  j:=o1[k].y;
  a[i,j]:=0;
  b[i,j]:='.';
  for i:=k to kol1-1 do
   begin
   o1[i].x:=o1[i+1].x;
   o1[i].y:=o1[i+1].y;
   o1[i].xp:=o1[i+1].xp;
   o1[i].yp:=o1[i+1].xp;
   o1[i].life:=o1[i+1].life;
   o1[i].baby:=o1[i+1].baby;
   end;
  o1[kol2].x:=-1;
  o1[kol2].y:=-1;
  kol1:=kol1-1;
  end;
 end;
 
for k:=1 to kol2 do
 begin
 if o2[k].life=0
  then
  begin
  i:=o2[k].x;
  j:=o2[k].y;
  a[i,j]:=0;
  b[i,j]:='.';
  for i:=k to kol2-1 do
   begin
   o2[i].x:=o2[i+1].x;
   o2[i].y:=o2[i+1].y;
   o2[i].xp:=o2[i+1].xp;
   o2[i].yp:=o2[i+1].xp;
   o2[i].life:=o2[i+1].life;
   o2[i].baby:=o2[i+1].baby;
   end;
   o2[kol2].x:=-1;
   o2[kol2].y:=-1;
   kol2:=kol2-1;
 
  end;
 end;
 
//-------------------------------------------------
 
  //Потомки
  for k:=1 to kol1 do
   begin
   if (o1[k].baby=0) and (o1[k].xp<>-1)
    then
    begin
    o1[k].baby:=12;
    kol1:=kol1+1;
    o1[kol1+1].x:=o1[k].xp;
    o1[kol1+1].y:=o1[k].yp;
    o1[kol1+1].baby:=12;
    o1[kol1+1].life:=10;
    end;
   end;
 
  for k:=1 to kol2 do
   begin
   if (o2[k].baby=0) and (o2[k].xp<>-1)
    then
    begin
    o2[k].baby:=12;
    kol2:=kol2+1;
    o2[kol1+1].x:=o2[k].xp;
    o2[kol1+1].y:=o2[k].yp;
    o2[kol1+1].baby:=8;
    o2[kol1+1].life:=9;
    end;
   end;
//--------------------------------------------
 
randomize;
//Еда
 if food=5
 then begin
 
 n3:=random(7)+5;
 for k:=1 to n3 do
  begin
   l3:
   i:=random(20)+1;
   j:=random(20)+1;
   if (a[i,j]=1) or  (a[i,j]=2) or  (a[i,j]=3)
    then goto l3
    else  a[i,j]:=3;
  end;
 clrscr;
 for j:=1 to 21 do
  begin
   for i:=1 to 21 do
    begin
     if a[i,j]=3
      then b[i,j]:='*';
     write(b[i,j]:2);
    end;
    writeln;
   end;
 readkey;
 food:=0;
 end;
 //------------------------------------------
 
 //Блуждание 1-------------------------------------
 for k:=1 to kol1 do
  begin
   i:=o1[k].x;
   j:=o1[k].y;
   if (((a[i+1,j]=1) or (a[i+1,j]=2))
    and ((a[i-1,j]=1) or (a[i-1,j]=2))
    and ((a[i,j+1]=1) or (a[i,j+1]=2))
    and ((a[i,j-1]=1) or (a[i,j-1]=2)))
     then begin  o1[k].life:=o1[k].life-1; o1[k].baby:=o1[k].baby-1; o1[k].xp:=-1; o1[k].yp:=-1; end
     else if a[i+1,j]=3
      then begin a[i,j]:=0; b[i,j]:='#';  o1[k].life:=10;o1[k].baby:=o1[k].baby-1; a[i+1,j]:=1; o1[k].xp:=i; o1[k].yp:=j; i:=i+1;  end
      else if a[i-1,j]=3
       then begin a[i,j]:=0; b[i,j]:='#';  o1[k].life:=10;o1[k].baby:=o1[k].baby-1; a[i-1,j]:=1; o1[k].xp:=i; o1[k].yp:=j; i:=i-1; end
       else if a[i,j+1]=3
        then begin a[i,j]:=0; b[i,j]:='#';  o1[k].life:=10;o1[k].baby:=o1[k].baby-1; a[i,j+1]:=1; o1[k].xp:=i; o1[k].yp:=j; j:=j+1; end
        else if a[i,j-1]=3
         then begin a[i,j]:=0; b[i,j]:='#';  o1[k].life:=10;o1[k].baby:=o1[k].baby-1; a[i,j-1]:=1; o1[k].xp:=i; o1[k].yp:=j; j:=j-1; end
         else
          begin
          l4:
          ch:=random(4);
          if (a[i+1,j]=0) and (ch=0)
           then begin a[i,j]:=0; b[i,j]:='#';  o1[k].life:=o1[k].life-1;o1[k].baby:=o1[k].baby-1; a[i+1,j]:=1; o1[k].xp:=i; o1[k].yp:=j; i:=i+1; end
           else if (a[i-1,j]=0) and (ch=2)
            then begin a[i,j]:=0; b[i,j]:='#';  o1[k].life:=o1[k].life-1;o1[k].baby:=o1[k].baby-1; a[i-1,j]:=1; o1[k].xp:=i; o1[k].yp:=j; i:=i-1; end
            else if (a[i,j+1]=0) and (ch=3)
             then begin a[i,j]:=0; b[i,j]:='#';  o1[k].life:=o1[k].life-1;o1[k].baby:=o1[k].baby-1; a[i,j+1]:=1; o1[k].xp:=i; o1[k].yp:=j; j:=j+1; end
             else if (a[i,j-1]=3) and (ch=1)
              then begin a[i,j]:=0; b[i,j]:='#';  o1[k].life:=o1[k].life-1;o1[k].baby:=o1[k].baby-1; a[i,j-1]:=1; o1[k].xp:=i; o1[k].yp:=j; j:=j-1; end
              else goto l4
          end;
    o1[k].x:=i;
    o1[k].y:=j;
    a[i,j]:=1;
    b[i,j]:='1';
  end;
 //--------------------------------
 
 //Уничтожение 2----------------------------
 for k:=1 to kol2 do
  begin
   i:=o2[k].x;
   j:=o2[k].y;
   if   (((a[i+1,j]=1) or (a[i+1,j]=2))
    and ((a[i-1,j]=1) or (a[i-1,j]=2))
    and ((a[i,j+1]=1) or (a[i,j+1]=2))
    and ((a[i,j-1]=1) or (a[i,j-1]=2)))
    or ((a[i,j-1]=3) or (a[i,j+1]=3) or (a[i-1,j]=3) or (a[i+1,j]=3))
     then begin o2[k].life:=o2[k].life-1; o2[k].xp:=-1; o2[k].yp:=-1; o1[k].baby:=o1[k].baby-1; end
     else begin
        l5:
        ch:=random(3);
        if (a[i+1,j]=0) and (ch=0)
         then begin a[i,j]:=0; b[i,j]:='#';  o2[k].life:=o2[k].life-1; o2[k].baby:=o2[k].baby-1; o2[k].xp:=i; o2[k].yp:=j;  i:=i+1; end
         else if (a[i-1,j]=0) and (ch=2)
          then begin a[i,j]:=0; b[i,j]:='#';  o2[k].life:=o2[k].life-1; o2[k].baby:=o2[k].baby-1; o2[k].xp:=i; o2[k].yp:=j;  i:=i-1; end
          else if (a[i,j+1]=0) and (ch=3)
           then begin a[i,j]:=0; b[i,j]:='#';  o2[k].life:=o2[k].life-1; o2[k].baby:=o2[k].baby-1; o2[k].xp:=i; o2[k].yp:=j;  j:=j+1; end
           else if (a[i,j-1]=3) and (ch=1)
            then begin a[i,j]:=0; b[i,j]:='#';  o2[k].life:=o2[k].life-1; o2[k].baby:=o2[k].baby-1; o2[k].xp:=i; o2[k].yp:=j;  j:=j-1; end
            else goto l5
            end;
       o2[k].x:=i;
       o2[k].y:=j;
       a[i,j]:=2;
       b[i,j]:='2';
 
  end;
 //---------------------------------
 
 for i:=0 to 22 do
 a[i,0]:=a[i,22];
  for j:=0 to 22 do
 a[0,j]:=a[22,j];
clrscr;
 for j:=1 to 21 do
  begin
   for i:=1 to 21 do
    begin
     if a[i,j]=1
      then b[i,j]:='1';
     if a[i,j]=2
      then b[i,j]:='2';
      if a[i,j]=0
      then b[i,j]:='#';
     write(b[i,j]:2);
    end;
    writeln;
   end;
 
 readkey;
//----------------------------------------
 food:=food+1;
 end;
 
 
end.
если что то задача к этой программе вот такая:"Цель - создать клеточный автомат, моделирующий динамику численности двух биологических видов, питающихся одним кормом.
Жизненное пространство представляет собой клетчатую доску с тороидальными граничными условиями, то есть соседями справа у клеток крайнего правого столбца являются клетки крайнего левого столбца, а соседями сверху у клеток первой строки являются клетки последней строки. Это пространство заселено двумя биологическими видами. При этом каждый экземпляр помещается не в клетку, а в узел сетки, так что соседей всего четыре – сверху, снизу, справа и слева (узлы по диагонали соседями не считаются).

Правила клеточного автомата:

1) Корм воспроизводится в клетках каждые Nкорм шагов
2) Существуют два биологических вида, которые характеризуются двумя параметрами каждый: скоростью воспроизводства (Nвоспр) и временем жизни (Nжиз), определяющим максимальное число шагов до следующего принятия пищи
3) Начальное количество особей каждого вида помещается случайным образом в узлы прямоугольной тороидальной сетки. Всем особям приписывается случайный возраст
4) Если за Nжиз шагов особь ничего не съедает, то она погибает. Если особь выживает в течение Nвоспр шагов, у нее появляется потомок. Новая особь помещается в предыдущую позицию родителя
5) Каждый из видов использует собственную стратегию поведения.


Возможные стратегии поведения:
1. «Блуждание»
a. Если корма в соседних клетках нет, то переместиться в случайном направлении
b. Если корм в соседних клетках есть, переместиться в одну из них и съесть корм
2. «Уничтожение»
a. Если корма в соседних клетках нет, то переместиться в случайном направлении
b. Если корм в соседних клетках есть, то оставаться на месте, пока не будет съеден весь корм в соседних клетках, после этого переместиться в случайном направлении

Задание:
4) Написать программу, реализующую этот клеточный автомат. Программа должна предусматривать возможность сохранения в файл количества особей каждого вида на каждом шаге.
"
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 00:09. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru