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

Игра "жизнь" - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Подключение двух хэдеров http://www.cyberforum.ru/cpp/thread33928.html
Необходимо подключить два хэдера, в которых пересекается содержимое и получаем conflicting types... first declaration of *** was here... Но подключить надо оба. Не подскажете, есть ли выход из...
C++ Макросы условного компилирования С++ Помогите пожалуйста студенту. Кто шарит по теме макросов. Немогу понять что с меня хотят. Помогите решить задачку(должно быть не сложно): Используя макросы условного компилирования и оператора... http://www.cyberforum.ru/cpp/thread33462.html
C++ Разбить N на более простые числа, в сумме дающие это N
Нашел я как-то в одной книге задачу. До сих пор бьюсь над ее решением. Может кто подскажет программу для ее решения (на Visual C++,либо на VBA либо на Паскале))). Вот текст задачи (на первый взгляд,...
C++ Шашки
Вкратце опишу суть проблемы. Препод задал лабу делать что-то на подобии шашек. Только само задание состоит в том что, на доске появляется рандомное кол-во шашек на рандомных клетках. Пользователю...
C++ Рандомное перемещение картинок(подробно) http://www.cyberforum.ru/cpp/thread31526.html
У меня задача сделать игру Парные картинки. У меня есть зарание раставленые 24 картинки тобишь (12х2). Мне надо, чтобы они все перемешались в рандомном порядке но раставились по координатам уже...
C++ Borland C++ 5.5 LINE TOOLS Привет всем! У меня только 1 вопрос КАК ВВОДИТЬ команды в Borland C++ 5.5 LINE TOOLS простите, закалибался уже ей богу... подробнее

Показать сообщение отдельно
kracav4eg
1 / 1 / 0
Регистрация: 08.05.2009
Сообщений: 11

Игра "жизнь" - C++

17.05.2009, 00:33. Просмотров 972. Ответов 3
Метки (Все метки)

Кому надо..выкладываю код этой программы...
перед этим создаете файл под названием life.txt и там вводите в матрицу 10 на 10 произвольный набор 0 или 1.

можете сами поменять размерность матрицы в коде..если хотит

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
Алгоритм: 
#include <iostream>
#include <fstream>
using namespace std;
 
void proverka( int a[10][10],int i,int j,int &n,int N)
{   n=0;
    if(a[(i-1)<0?N:i-1][(j-1)<0?N:j-1]==1)
    n++;
    if(a[(i-1)<0?N:i-1][j]==1)
    n++;
    if(a[(i-1)<0?N:i-1][(j+1)%N]==1)
    n++;
    if(a[i][(j+1)%N]==1)
    n++;
    if(a[(i+1)%N][(j+1)%N]==1)
    n++;
    if(a[(i+1)%N][j]==1)
    n++;
    if(a[(i+1)%N][(j-1)<0?N:j-1]==1)
    n++;
    if(a[i][(j-1)<0?N:j-1]==1)
    n++;
}
//--------------------------------------
int main()
{   int i,j,N=9,n=0,chet=0,kol;
    int pred[10][10],sled[10][10];
    fstream matr("life.txt",ios::in);
 
    if (matr)
    cout<<"da"<<endl;
 
    else cout<<"net"<<endl;;
    for(i=0;i<10;i++){
    for(j=0;j<10;j++)
    matr>>pred[i][j];
    }
    cout<<"vvedit kol pokoleni"<<'\n';
cin>>kol;
cout<<'\n';
 
    while(chet<kol){
    for(i=0;i<10;i++){
    for(j=0;j<10;j++)
    {
    proverka(pred,i,j,n,N);
    if(pred[i][j]==0 && n==3)
    sled[i][j]=1;
    else
    if(pred[i][j]==1 && (n==3||n==2))
    sled[i][j]=1;
    else
    sled[i][j]=0;
    cout<<sled[i][j];
        }
        cout<<'\n';
    }
    for(i=0;i<10;i++){
    for(j=0;j<10;j++)
    pred[i][j]=sled[i][j];}
 
    cout<<"----------"<<endl;
    chet++;
    }
 
matr.close();
 
    return 0;
}
0
Вложения
Тип файла: txt life.txt (208 байт, 68 просмотров)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru