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

Клеточные автоматы на с++ - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Занести в массив данные с помощью указателей, определить сумму и колличество положительных элементов http://www.cyberforum.ru/cpp-beginners/thread1015310.html
дан вещественный массив vector <float> D5 . занести в массив данные с помощью указателей , определить сумму и колличество положительных элементов , вывести на экран полученный массив и адреса элементов . помогите с кодом
C++ Создание специализации шаблонной функции и задача на std::vector Здравствуйте, подскажите, пожалуйста: 1.В чем ошибка объявления специализации шаблонной функции в header.h template <typename T> void VectInfo(const std::vector<T>& ref){ } http://www.cyberforum.ru/cpp-beginners/thread1015253.html
Минимальный элемент массива C++
Написать функцию нахождения минимального значения элемента массива. #include<iostream.h> int max(int * arr, int size) { int max = arr; for(int i=1; i<size; i++) if(arr > max) max = arr; return max; Как продолжить?
Функция check, не могу разобраться C++
Подскажите пожалуйста, функция Check (int size, float &len): Какие параметры передаются по значению, какие по ссылке? Какой из параметров защищен от изменения функцией? В гугле ничего найти про эту функцию не могу. Заранее спасибо.
C++ Замещение слов в строке http://www.cyberforum.ru/cpp-beginners/thread1015195.html
Написать программу замещения первой половины строки второй, а второй – первой. Borland 3.1, но не принципиально. Заранее спасибо.
C++ Определить средне геометрическое квадратов некоторых элементов двухмерного массива Ввести двумерный массив А 3*4. Определить средне геометрическое квадратов элементов стоящих на позициях у которых хотя бы один индекс кратен 3.ПОМОГИТЕ РЕШИТЬ ПОЗЯЗЯ подробнее

Показать сообщение отдельно
Катенько
0 / 0 / 0
Регистрация: 17.09.2013
Сообщений: 15

Клеточные автоматы на с++ - C++

22.11.2013, 12:01. Просмотров 620. Ответов 0
Метки (Все метки)

Добрый день/вечер/ночь, друзья
Небольшая загвоздка в решении клеточных автоматов. Не могу понять как сделать так, чтобы клетка меняла свое состояние на каждой итерации. В моей программе клетка имеет лишь 2 состояния "живая" или "мертвая". Но препод сказал, что нужно сделать так, чтобы клетка на каждом шаге меняла состояние с "мертвой" на 2, потом на 3 и т.д до 8, и если она оживает(в разрез правилу "if ((Counter < 2) || (Counter > 3))", это значит, что если выполняется данное условие, то клетка умирает), то принимает значение "живая"

Т.е. чтобы клетка которая умерла, начала потихоньку возрождаться(если выполняется нужное условие), принимая состояния от 2 до 8, и дальше либо умирала, либо возраждалась(опять же исходя из условия "if" )

В программе есть глайдер, для наглядного просмотра работы программы
C++
1
2
3
4
5
6
7
8
// Глайдер
    /*
    bArray[1]=true;
    bArray[Width + 2]=true;
    bArray[Width * 2]=true;
    bArray[Width * 2 + 1]=true;
    bArray[Width * 2 + 2]=true;
    */
Активировать его можно, сняв с него комментарии и заключить в комментарии вот это.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
// Рандомизируем массив
     //-----------------------------------------------------------------
     
   /* for (int y = 0; y < Heigth; y++)
    {
        for(int x = 0; x < Width; x++)
        {
              bArray[x + y * Width]  = rand() % 2; 
                
              if (bArray[x + y * Width])
              {
                     cout << Live;          
              }
              else
              {
                  cout << Dead;
              }
         }      
         cout <<  '\n';
     }
cout <<  '\n';
cout <<  '\n';
К сожалению мой код, где я пыталась сделать тщетные попытки на столько убогий, что стыдно его показывать ...Но принцип работы был таков что, у меня все происходило так: Менялись состояния не тех клеток, которые нужны, а всех кроме них, то есть весь массив. И после состояния 8, клетка не возрождалась.

Не прошу писать код, если кому то покажется это слишком большим шиком, подайте хотя бы идею решения, но только не банальные "мол тут нужно в состоянии прописать код".

Заранее большое спасибо за участие! Код программы указан ниже.
C++
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
#include <iostream.h>
#include <conio.h>
#include <ctime>
 
using namespace std;
 
int main()
{
    //Константы
    const int Width(77), Heigth(10); //Ширина и высота поля
    const char Live(219), Dead('.'); //Состояния
    
    //Переменные
    int Itterations(20); //Колличество итераций
    
    //Массивы
    bool bArray[Width * Heigth] = {false} ; 
    bool bTempArray[Width * Heigth] = {false} ; 
    
    // Рандомайзер
    srand((unsigned)time(NULL));
    
    /*
    bArray[1]=true;
    bArray[Width + 2]=true;
    bArray[Width * 2]=true;
    bArray[Width * 2 + 1]=true;
    bArray[Width * 2 + 2]=true;
    */
    
 
    
    //-----------------------------------------------------------------------
    // Показать содержимое массива
    //-----------------------------------------------------------------------
    
    for (int y = 0; y < Heigth; y++)
    {
        for(int x = 0; x < Width; x++)
        {
              if (bArray[x + y * Width])
              {
                     cout << Live;          
              }
              else
              {
                  cout << Dead;
              }
         }      
         cout <<  '\n';
     }      
     cout <<  '\n';
     cout <<  '\n';
     //-----------------------------------------------------------------
     // Рандомизируем массив
     //-----------------------------------------------------------------
     
   /* for (int y = 0; y < Heigth; y++)
    {
        for(int x = 0; x < Width; x++)
        {
              bArray[x + y * Width]  = rand() % 2; 
                
              if (bArray[x + y * Width])
              {
                     cout << Live;          
              }
              else
              {
                  cout << Dead;
              }
         }      
         cout <<  '\n';
     }
cout <<  '\n';
cout <<  '\n';
*/
     //-----------------------------------------------------------------
     // Вывод поколений
     //-----------------------------------------------------------------
     
     for (int g = 0; g < Itterations; g++)
         {
             for (int y = 0; y < Heigth; y++)
                  {
                      for(int x = 0, Counter = 0; x < Width; x++)
                              {
                              //-----------------------------------------------------------------
                              // Анализ соседних клеток
                              //-----------------------------------------------------------------
                              
                              // #..
                              // ...
                              // ...
                              
                              if (((x - 1) >= 0) && ((y - 1) >= 0))
                              {
                                  if   (bArray[(x - 1) + (y - 1) * Width]) Counter++;
                              }     
                              
                              // .#.
                              // ...
                              // ...
                              
                              if (y - 1 >= 0)
                              {
                                  if   (bArray[x  + (y - 1) * Width]) Counter++;
                              }    
                              // ..#
                              // ...
                              // ...
                              
                              if (((x + 1) <= Width) && ((y - 1) >= 0))
                              {
                                  if   (bArray[(x + 1) + (y - 1) * Width]) Counter++;
                              }  
                              
                              // ...
                              // #..
                              // ...
                              
                              if ((x - 1) >= 0)
                              {
                                  if   (bArray[(x - 1) + y  * Width]) Counter++;
                              }       
                              
                              // ...
                              // .#.
                              // ...
                              
                              if ((x + 1) <= Width - 1)
                              {
                                  if   (bArray[(x - 1) + y  * Width]) Counter++;
                              }  
                              
                              // ...
                              // ...
                              // #..
                              
                              if (((x - 1) >= 0) && ((y + 1) <= Heigth - 1))
                              {
                                  if   (bArray[(x - 1) + (y + 1)  * Width]) Counter++;
                              } 
                              
                              // ...
                              // ...
                              // .#.
                              
                              if ((y + 1) <= (Heigth - 1))
                              {
                                  if   (bArray[x + (y + 1)  * Width]) Counter++;
                              } 
                              
                              // ...
                              // ...
                              // ..#
                              
                              if (((x + 1) <= (Width -1) && (y + 1) <= Heigth - 1))
                              {
                                  if   (bArray[(x + 1)+ (y + 1)  * Width]) Counter++;
                              } 
                              
                              //-----------------------------------------------------------------
                              // Определение состояния
                              //-----------------------------------------------------------------
                               if ((Counter < 2) || (Counter > 3))
                               {
                                    bTempArray[x + y *Width] = false;
                                    cout<< Dead;            
                               }    
                               else
                               {
                                   if ((!bTempArray[x + y *Width])   && (Counter != 3))
                                   {
                                     bTempArray[x + y *Width] = false;
                                     cout<< Dead;              
                                   }                 
                                   else
                                   {
                                       bTempArray[x + y *Width] = true;
                                       cout << Live;
                                   }           
                               }  
                               
                               Counter =0;
                               
                               
                               
                              } //Горизонтальные поля
                              
                              cout <<'\n';
                              
                  }// Вертикальные поля
                  
                  cout <<'\n';
                  cout <<'\n';
                  
                  for (int i =0; i < (Width * Heigth); i++)
                  {
                     bArray[i] = bTempArray[i]; 
                  }                    
         }    //Вывод поколений
getch ();
return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru