Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/3: Рейтинг темы: голосов - 3, средняя оценка - 5.00
2 / 1 / 1
Регистрация: 09.01.2017
Сообщений: 24

Игра "жизнь"

23.10.2022, 00:02. Показов 569. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
здравствуйте, написал данный код, а он отказывается работать, как я понял у меня есть выход за границы массива.
1. как это исправить?
2. как сделать в мейне чтобы по нажатию ентера обновлялась консоль по красивее, у меня требуется два раза нажать ентер.
3. false и true это 0 и 1 в int или так нельзя считать? (например есть bool1 = true и bool2 = true / a = bool1 + bool2 будет 2?)
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
#include <iostream>
#include <ctime>
#include <algorithm>
 
using namespace std;
 
bool** Start(int rows, int cols, int i, int j)
{
    bool** arr = new bool* [rows];
 
    for (int i = 0; i < rows; i++)
    {
        arr[i] = new bool[cols];
        for (int j = 0; j < cols; j++)
            arr[i][j] = false;
    }
 
    i = rand() % (rows - 2) + 1;
    j = rand() % (cols - 2) + 1;
 
    arr[i][j] = true;
    arr[i - 1][j - 1] = true;
    arr[i][j + 1] = true;
    arr[i + 1][j - 1] = true;
    arr[i + 1][j] = true;
 
    return arr;
}
 
bool death(bool **arr, int i, int j)
{
    int a;
    a = arr[i - 1][j - 1] + arr[i - 1][j] + arr[i - 1][j + 1] + arr[i][j - 1] + arr[i][j + 1] + arr[i + 1][j - 1] + arr[i + 1][j] + arr[i + 1][j + 1];
    return ((a == 2) && (a == 3)) ? false : true;
}
 
bool life(bool** arr, int i, int j)
{
    int a;
    a = arr[i - 1][j - 1] + arr[i - 1][j] + arr[i - 1][j + 1] + arr[i][j - 1] + arr[i][j + 1] + arr[i + 1][j - 1] + arr[i + 1][j] + arr[i + 1][j + 1];
    return (a == 3) ? true : false;
}
 
bool** Game(bool **arr, int rows, int cols)
{
    for (int i = 0; i < rows; i++)
    {
        for (int j = 0; j < cols; j++)
        {
            if (arr[i][j] == true)
            {
                if (death(arr, i, j))
                    arr[i][j] = false;
            }
            if (arr[i][j] == false)
            {
                if (life(arr, i, j))
                    arr[i][j] = true;
            }
        }
    }
    return arr;
}
 
void Delete_2_Array(bool** arr, int rows, int cols)
{
    for (int l = 0; l < rows; l++)
        delete[] arr[l];
    delete[] arr;
}
 
void Print_2_Array(bool** arr, int rows, int cols)
{
    for (int i = 0; i < rows; i++)
    {
        for (int j = 0; j < cols; j++)
            if(arr[i][j])
                cout << "*" << " ";
            else
                cout << "-" << " ";
        cout << endl;
    }
    cout << endl;
}
 
int main()
{
    srand(time(NULL));
 
    int rows = 20;
    int cols = 20;
    int i = 0;
    int j = 0;
    int k = 1;
 
    bool** arr = Start(rows, cols, i, j);
 
    while (cin.get() != 0)
    {
        /*Print_2_Array(arr, rows, cols);*/
        Game(arr, rows, cols);
        Print_2_Array(arr, rows, cols);
        
        cin.get();
        cout << "\033[2J\033[1;1H";
    }
 
    Delete_2_Array(arr, rows, cols);
 
 
}
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
23.10.2022, 00:02
Ответы с готовыми решениями:

игра жизнь
содержимое life.cpp// Life.cpp: определяет точку входа для консольного приложения. // #include &lt;iostream&gt; #include...

Игра Жизнь
Ну, правила игры таковы: - если клетка пустая но имеет ровно 3 соседа (вообще их 8), там появляется жизнь. - если клетка полная, но там...

Игра жизнь
Нужно написать игру &quot;Жизнь&quot; простым кодом. Только начал изучать c++

4
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,536
Записей в блоге: 1
23.10.2022, 01:58
эта неправильна игра жизнь
она не разделяет поле на предыдущее и следующее поколения
она обновляет клетки на основе проверки в уже частично обновлённом поле.
1
Вездепух
Эксперт CЭксперт С++
 Аватар для TheCalligrapher
13183 / 6819 / 1821
Регистрация: 18.10.2014
Сообщений: 17,259
23.10.2022, 02:15
Лучший ответ Сообщение было отмечено Shurller как решение

Решение

Цитата Сообщение от Shurller Посмотреть сообщение
bool** Start(int rows, int cols, int i, int j)
Зачем в функцию Start передаются значения i и j, если они там нигде не используются, а затираются случайными значениями?

Цитата Сообщение от Shurller Посмотреть сообщение
как я понял у меня есть выход за границы массива
Совершенно верно: выход за границы массива. А также проблема поколений, на которую указал Kuzia domovenok.

Цитата Сообщение от Shurller Посмотреть сообщение
как это исправить?
Это сначала у вас нужно спрашивать: как вы собираетесь обрабатывать клетки, которые располагаются рядом с краем игрового поля? Есть разные подходы.

* Можно считать, что за пределами игрового роля - пустота, т.е. нет соседей.
* Можно считать, что игровое поле представляет из себя тор, то есть выход за его границу с одной стороны считается входом с другой
* Еще какой-то вариант?

Сначала решите, что вы хотите реализовать, а затем реализуйте.

Цитата Сообщение от Shurller Посмотреть сообщение
у меня требуется два раза нажать ентер.
Ну так у вас два вызова cin.get(). Два написали - два получили.

Цитата Сообщение от Shurller Посмотреть сообщение
false и true это 0 и 1 в int или так нельзя считать?
Да, можно так считать.

---

И, как правильно заметил Kuzia domovenok выше, в правильной реализации решения о жизни/смерти следующего поколения должны приниматься на основе анализа состояния только нынешнего поколения. А у вас уже принятые решения о следующем поколении влияют на соседние решения о следующем поколении. Это неправильно.

В простейшем случае вам понадобится два игровых поля: нынешнее поколение и следующее поколение. Анализировать вы будете нынешнее поколение, а заполнять результатами - следующее поколение. Только когда следующее поколение полностью заполнено, оно становится нынешним.
0
place status here
 Аватар для gunslinger
3190 / 2227 / 640
Регистрация: 20.07.2013
Сообщений: 6,023
23.10.2022, 02:54
Игра Жизнь
0
2 / 1 / 1
Регистрация: 09.01.2017
Сообщений: 24
24.10.2022, 22:17  [ТС]
Починил свой код, работает исправно, игра движется, но отсюда пару вопросов, надеюсь вы сможете дать на них ответы:
1. как установить рандомное расположение стартовых живых клеток? если например расположение их в массиве я сделал, то вот как сделать чтобы форма самой этой фигуры живых клеток изменялась при каждом запуске, не понятно
2. ну и выход за границы я не смог додумать, проверку на выход я сделал, но чтобы при выходе "фигуры" она появлялась с другой стороны массива не смог.
3. в 21 строке у меня предупреждение "переполнение буфера", игра играется, но предупреждение мозолит глаза, что делать в этой ситуации? забить или есть варианты исправить?
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
#include <iostream>
#include <ctime>
 
using namespace std;
 
bool** Start(int rows, int cols)
{
    int i, j;
    bool** arr = new bool* [rows];
 
    for (int i = 0; i < rows; i++)
    {
        arr[i] = new bool[cols];
        for (int j = 0; j < cols; j++)
            arr[i][j] = false;
    }
 
    i = rand() % (rows - 2) + 1;
    j = rand() % (cols - 2) + 1;
 
    arr[i][j] = true;
    arr[i - 1][j - 1] = true;
    arr[i][j + 1] = true;
    arr[i + 1][j - 1] = true;
    arr[i + 1][j] = true;
 
    return arr;
}
 
bool** Start_tmp(int rows, int cols)
{
    bool** arr_tmp = new bool* [rows];
 
    for (int i = 0; i < rows; i++)
    {
        arr_tmp[i] = new bool[cols];
        for (int j = 0; j < cols; j++)
            arr_tmp[i][j] = false;
    }
 
    return arr_tmp;
}
 
bool death(bool **arr, int i, int j, int rows, int cols)
{
    int a = 0;
    if (i == 0)
    {
        if (j == 0)
            a = arr[i][j + 1] + arr[i + 1][j] + arr[i + 1][j + 1];
        else if (j == rows - 1)
            a = arr[i][j - 1] + arr[i + 1][j - 1] + arr[i + 1][j];
        else
            a = arr[i][j - 1] + arr[i][j + 1] + arr[i + 1][j - 1] + arr[i + 1][j] + arr[i + 1][j + 1];
    }
    else if (i == cols - 1)
    {
        if (j == 0)
            a = arr[i - 1][j] + arr[i - 1][j + 1] + arr[i][j + 1];
        else if (j == rows - 1)
            a = arr[i - 1][j - 1] + arr[i - 1][j] + arr[i][j - 1];
        else
            a = arr[i - 1][j - 1] + arr[i - 1][j] + arr[i - 1][j + 1] + arr[i][j - 1] + arr[i][j + 1];
    }
    else
    {
        if (j == 0)
            a = arr[i - 1][j] + arr[i - 1][j + 1] + arr[i][j + 1] + arr[i + 1][j] + arr[i + 1][j + 1];
        else if (j == rows - 1)
            a = arr[i - 1][j - 1] + arr[i - 1][j] + arr[i][j - 1] + arr[i + 1][j - 1] + arr[i + 1][j];
        else
            a = arr[i - 1][j - 1] + arr[i - 1][j] + arr[i - 1][j + 1] + arr[i][j - 1] + arr[i][j + 1] + arr[i + 1][j - 1] + arr[i + 1][j] + arr[i + 1][j + 1];
    }
    return (a == 2) || (a == 3) ? false : true;
}
 
bool life(bool** arr, int i, int j, int rows, int cols)
{
    int a = 0;
    if (i == 0)
    {
        if (j == 0)
            a = arr[i][j + 1] + arr[i + 1][j] + arr[i + 1][j + 1];
        else if (j == rows - 1)
            a = arr[i][j - 1] + arr[i + 1][j - 1] + arr[i + 1][j];
        else 
            a = arr[i][j - 1] + arr[i][j + 1] + arr[i + 1][j - 1] + arr[i + 1][j] + arr[i + 1][j + 1];
    }
    else if (i == cols - 1)
    {
        if (j == 0)
            a = arr[i - 1][j] + arr[i - 1][j + 1] + arr[i][j + 1];
        else if (j == rows - 1)
            a = arr[i - 1][j - 1] + arr[i - 1][j] + arr[i][j - 1];
        else
            a = arr[i - 1][j - 1] + arr[i - 1][j] + arr[i - 1][j + 1] + arr[i][j - 1] + arr[i][j + 1];
    }
    else
    {
        if (j == 0)
            a = arr[i - 1][j] + arr[i - 1][j + 1] + arr[i][j + 1] + arr[i + 1][j] + arr[i + 1][j + 1];
        else if (j == rows - 1)
            a = arr[i - 1][j - 1] + arr[i - 1][j] + arr[i][j - 1] + arr[i + 1][j - 1] + arr[i + 1][j];
        else
            a = arr[i - 1][j - 1] + arr[i - 1][j] + arr[i - 1][j + 1] + arr[i][j - 1] + arr[i][j + 1] + arr[i + 1][j - 1] + arr[i + 1][j] + arr[i + 1][j + 1];
    }
    return (a == 3) ? true : false;
}
 
bool** Game(bool **arr, bool** arr_tmp, int rows, int cols)
{
    for (int i = 0; i < rows; i++)
    {
        for (int j = 0; j < cols; j++)
        {
            if (arr[i][j])
            {
                arr_tmp[i][j] = arr[i][j];
                if (death(arr, i, j, rows, cols))
                    arr_tmp[i][j] = false;
            }
            else
            {
                if (life(arr, i, j, rows, cols))
                    arr_tmp[i][j] = true;
            }
        }
    }
    return arr, arr_tmp;
}
 
bool** arr_to_arr_tmp(bool** arr_tmp, int rows, int cols)
{
    bool** arr = new bool* [rows];
 
    for (int i = 0; i < rows; i++)
    {
        arr[i] = new bool[cols];
        for (int j = 0; j < cols; j++)
            arr[i][j] = arr_tmp[i][j];
    }
    return arr;
}
 
void Delete_2_Array(bool** arr, int rows, int cols)
{
    for (int l = 0; l < rows; l++)
        delete[] arr[l];
    delete[] arr;
}
 
void Print_2_Array(bool** arr, int rows, int cols)
{
    for (int i = 0; i < rows; i++)
    {
        for (int j = 0; j < cols; j++)
        {
            if (arr[i][j])
                cout << "*" << " ";
            else
                cout << "-" << " ";
        }  
        cout << endl;
    }
    cout << endl;
}
 
int main()
{
    srand(time(NULL));
 
    int rows = 20;
    int cols = 20;
 
    bool** arr = Start(rows, cols);
    bool** arr_tmp = Start_tmp(rows, cols);
 
    while (true)
    {
        Print_2_Array(arr, rows, cols);
        
        Game(arr, arr_tmp, rows, cols);
        
        arr = arr_to_arr_tmp(arr_tmp, rows, cols);
 
        cin.get();
        system("cls");
    }
    Delete_2_Array(arr, rows, cols);
    Delete_2_Array(arr_tmp, rows, cols);
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.10.2022, 22:17
Помогаю со студенческими работами здесь

Игра жизнь
Помогите пожалуйста с решением. Код нужен на С++ «Жизнь» – компьютерная игра, придуманная английским математиком Джоном Конвеем (John...

Игра Жизнь
Написал вот такую реализацию: #include &quot;stdafx.h&quot; #include &quot;iostream&quot; #include &quot;clocale&quot; using namespace std; int...

Игра в жизнь Конвей
Чего то я намудрил помогите разобраться пожалуйста #include&lt;math.h&gt; #include &lt;time.h&gt; #include &lt;stdio.h&gt; #include...

Игра «Жизнь» Конвея(обратная)
Помогите реализовать игру &quot;Жизнь&quot;, но не прямую, а обратную, то-есть что бы из текущего поля получалось предшествующее ему. Я знаю что...

Игра жизнь (бесконечное пространство)
Надо сделать бесконечное пространство для игры &quot;жизнь&quot;, примерно понимаю как это сделать, но что то не получается,надо в подпрограмму rules...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru