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

Маленькие игры на Си++ для консолили(только псевдографика).(нужен совет) - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Динамическая память (строки), деструктор http://www.cyberforum.ru/cpp-beginners/thread595591.html
Привет. Бьюсь уже час, помогите разобраться. Написал программу, в одной функции память выделил, в другой освобождаю. После выполнения программы вылетает ошибка (вложение) понял что ошибка в деструкторе. но конкретнее? что конкретно не так делаю??? речь про класс alcohol ! fluid работает отлично (тоже странно, одинаковые же блин!) help! zad1.h #pragma once
C++ Подсчитать число элементов, входящих в непрерывные последовательности отрицательных чисел ЗАДАЧА Задан одномерный массив Х вещественных чисел. Подсчитать число элементов, входящих в непрерывные последовательности отрицательных чисел, содержащие k и более элементов. помогите с програмным кодом... http://www.cyberforum.ru/cpp-beginners/thread595590.html
Некоректно работает функция pow C++
Здравствуйте! Пользуюсь компилятором Code Blocks! Использовал в программе для возведения в степень функцию pow, и заметил что некоторую степень считает не правильно! А именно 10 во второй, четвертой, восьмой, девятой выдаёт результат на 1 меньше! Тоесть 99, 9999 и т.д! Подскажите пожалуйста, это проблема в компиляторе, или сама функция так не коректно работает везде ?
Шаблон дерева. Найти элементы на заданной глубине C++
Задача: Разработать шаблон класса для работы с двоичным деревом поиска. Реализовать следующие действия добавление элемента в дерево; удаление элемента из дерева; обход дерева (для печати элементов и т.д.); поиск в дереве. Найти количество элементов на заданной глубине. Шаблон реализовала:
C++ Записать этот массив в бинарный файл одной записью (не в цикле) http://www.cyberforum.ru/cpp-beginners/thread595552.html
Создать файл в блокноте с числами, например: 1.4 1.234 2.104 и т.д. Считывать этот файл в массив, который надо динамически расширять под каждое считанное число, пока файл не будет прочитан Записать этот массив в бинарный файл одной записью (не в цикле) Заранее спасибо!!!!
C++ Дано натуральное число n. Найти A1B1+A2B2+... Дано натуральное число n. Найти A1B1+A2B2+...AnBn,где A1=B1=1;Ak=1/2*(sqrt(B(k-1))+1/2*A(k-1));Bk=2*(A(k-1))^2;k=1,2...n. подробнее

Показать сообщение отдельно
tihonya
11 / 7 / 1
Регистрация: 30.05.2012
Сообщений: 107
01.07.2012, 23:06  [ТС]     Маленькие игры на Си++ для консолили(только псевдографика).(нужен совет)
Вот наконец то, написал играбельный МОРСКОЙ БОЙ, хромает только компоновка кода.
Функции по разному понатыканы, все компилируется в студии! 5 файлов:
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
//Start_M.cpp
#include <iostream>
#include <stdlib.h>
#include <time.h>
#include <conio.h>
#include <Windows.h>
 
using namespace std;
#include "Class_player.h"
#include "Funk_for_MB.h"
    player human;
    player computer;
 
 
 
 
int main()
{
int whoisturn=1;
int *korC, *tmp,*korH;
int palubC=0,palubH=0;
  setlocale(LC_CTYPE, "Russian");
  int message = 0; // переменная хранит коды сообщений
// установка начального значения генератора случайных чисел
  srand(time(NULL) );
  human.ships_init();
  computer.ships_init();
//--------------------------
 
  while (message != 2)
  {
  map_init(map);
    int user_input = 0;
    system("cls");
    show(map);
/* map_initC(map); Это если хотите подглядывать поле кмпьютера!(для отладки)
  cout<<endl;
      show(map);*/
    message = 0;
 
int characte, digi;
char character, digit;
 
  
 
switch(whoisturn){
    case 1:
        cout<<endl<<"Ход игрока"<<endl;
    input(human, character, digit);
//character=rand()%10;
//digit=rand()%10;
   if( human.turn(computer,character, digit)){
       human.hits[character][digit]=9;
       if(palubC==0){
        palubC=1;
        korC=new int[palubC*2];
        *(korC)=character;
        *(korC+1)=digit;
       }
       else
       {
        palubC++;
        tmp=new int[palubC*2];
        for(int i=0;i<(palubC*2)-2;i++)
        *(tmp+i)=*(korC+i);
        delete[]korC;
        korC=tmp;
        *(korC+((palubC*2)-2))=character;
        *(korC+((palubC*2)-2)+1)=digit;
       }
 
    if  (ship_die(computer,korC,palubC*2)){
        do_after_die(human,korC,palubC*2);
    system("cls");  
    cout<<endl<<"Вы УБИЛИ корабль компьтера!!!";
    Sleep(3000);
        whoisturn=1;
        palubC=0;
        delete[] korC;
    }
    else
    {
    system("cls");  
    cout<<endl<<"Вы РАНИЛИ корабль компьтера!!!\n\t\tНастоятельно рекомендую ДОБИТЬ иначе будут глюки!!! :))";
    Sleep(3000);
        whoisturn=1;
    }
   }
   else
   {
    human.hits[character][digit]=1;
    if( palubH>0)
    whoisturn=3;
    else
    whoisturn=2;
   }
//      system("pause");
        break;
    case 2:
        {
 
computer.forturn(computer,characte, digi);
if (computer.turn(human,characte, digi)){
    computer.hits[characte][digi]=9;
    palubH=1;
    korH=new int[palubH*2];
    *(korH)=characte;
    *(korH+1)=digi;
    if  (ship_die(human,korH,palubH*2)){
    do_after_die(computer,korH,palubH*2);
    system("cls");  
    cout<<endl<<"Компьтер УБИЛЛЛ ваш корабль!!!";
    Sleep(3000);
        whoisturn=2;
        palubH=0;
        delete[] korH;
        
    }
    else
    {
        system("cls");
        cout<<endl<<"Компьтер РАНИЛЛЛ ваш корабль!!!";
        Sleep(3000);
        whoisturn=3;
    }
}
else
{
        computer.hits[characte][digi]=1;
                whoisturn=1;
}
 
}
break;
    case 3:
    input(characte, digi,computer ,korH,2*palubH);
   if( computer.turn(human,characte, digi)){
       computer.hits[characte][digi]=9;
       palubH+=1;
        tmp=new int[palubH*2];
        for(int i=0;i<(palubH*2)-2;i++)
        *(tmp+i)=*(korH+i);
        delete[]korH;
        korH=tmp;
        *(korH+((palubH*2)-2))=characte;
        *(korH+((palubH*2)-2)+1)=digi;
    if  (ship_die(human,korH,palubH*2)){
        do_after_die(computer,korH,palubH*2);
 
        delete [] korH;
        palubH=0;
    system("cls");  
    cout<<endl<<"Компьтер УБИЛЛЛ ваш корабль!!!";
    Sleep(3000);
 
        whoisturn=2;
    }
    else
    {
        system("cls");
        cout<<endl<<"Компьтер РАНИЛЛЛ ваш корабль!!!";
        Sleep(3000);
        whoisturn=3;
    }
   }
   else
   {
    computer.hits[characte][digi]=1;
    whoisturn=1;
   }
        /*system("pause");*/
        break;
}
computer.defeat();
human.defeat();
 
    message = check_ending();
  }
if(computer.defeat_flag){
    system ("cls");
    cout<<"\n\tПоздравляю ВАС ИГРОК - ФЛОТ противника разбит!!!";
}
if(human.defeat_flag){
    system ("cls");
    cout<<"\n\tКомпьютер РАЗБИЛ ВАШ Флот- эх игрок ;)!!!";
}   
  getch();
  return 0;
}
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
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
//Funk_for_MB.cpp
#include "Class_player.h"
#include <iostream>
using namespace std;
const int s=13, c=29;
char numbers[]={'0','1','2','3','4','5','6','7','8','9'};
bool chekRange(int St,int _1,int _2,int End){
    if ((St<=_1)&&(St<=_2))
        if((End>=_1)&&(End>=_2))
            return true;
    return false;
}
void show(char map[s][c]){
    cout<<endl;
    for (int i=0;i<s;i++){
        for(int j=0;j<c;j++)
            cout<<map[i][j];
        cout<<endl;}
    }
void map_init(char map[s][c]){//здесь происходит помещение данных о кораблях игрока которые берутся из human.ships
    for (int i=0;i<s;i++)
        for(int j=0;j<c;j++){
            if((j>=2)&&(j<=11))
                if((i>=2)&&(i<=11)){
                    if (human.ships[i-2][j-2]==1)
                    map[i][j]= 49;
                    if (human.ships[i-2][j-2]==2)
                    map[i][j]= 50;
                    if (human.ships[i-2][j-2]==3)
                    map[i][j]= 51;
                }
            if((j>=17)&&(j<=26))
                if((i>=2)&&(i<=11)){
                    if (human.hits[i-2][j-17]==0)
                    map[i][j]= 48;
                    if (human.hits[i-2][j-17]==1)
                    map[i][j]= 49;
                    if (human.hits[i-2][j-17]==9)
                    map[i][j]= 'A';
 
        }
}
}
void map_initC(char map[s][c]){
    //функция для записи в графический интерфейс полей компьтера
    //Эта функция пригодится для отладки
    for (int i=0;i<s;i++)
        for(int j=0;j<c;j++){
            if((j>=2)&&(j<=11))
                if((i>=2)&&(i<=11)){
                    if (computer.ships[i-2][j-2]==1)
                    map[i][j]= 49;
                    if (computer.ships[i-2][j-2]==2)
                    map[i][j]= 50;
                    if (computer.ships[i-2][j-2]==3)
                    map[i][j]= 51;
                }
            if((j>=17)&&(j<=26))
                if((i>=2)&&(i<=11)){
                    if (computer.hits[i-2][j-17]==0)
                    map[i][j]= 48;
                    if (computer.hits[i-2][j-17]==1)
                    map[i][j]= 49;
                    if (computer.hits[i-2][j-17]==9)
                    map[i][j]= 'A';
 
        }
}
}
int check_ending(){
    if((human.defeat_flag)||(computer.defeat_flag))
    return 2;
    else 
        return 0;
}
void input (player& H, char& character,char& digit){
    int S, C, TR=0;
    for(;;){
    cout<<endl<<"Enter координату по строкам"<<endl;
    character=getche();
    cout<<endl<<"Enter координату по столбцам"<<endl;
    digit=getche();
    for(int i=0;i<10;i++){
        if (numbers[i] == character){
            S=i;
            TR++;
        }
        if (numbers[i] == digit){
            C=i;
            TR++;
        }
    }
    if(TR==2){
    if(H.hits[S][C]==0){
    character=S;
    digit=C;
    return ;
    }
    else
    cout<<"\nВы ввели значени куда уже стреляли введите еще раз:\n";
    }
    else
    {
    cout<<"\nФигню вводить не надо!!\n";
    TR=0;
    }
    }
 
 
}
void input (int& character,int& digit,player& C, int *kor, int n){
    int match=1;
    if(n==2)
        for(;;){
            character=*kor;
            digit=*(kor+1);
            switch(match)
            {
            case 1:
                if((chekRange(0,character+1,digit,9))&&(C.hits[character+1][digit]==0)){
                    character++;
                    return ;
                }
                else
                    match=2;
            break;
            case 2:
                if((chekRange(0,character-1,digit,9))&&(C.hits[character-1][digit]==0)){
                    character--;
                    return ;
                }
                else
                    match=3;
 
                break;
            case 3:
                if((chekRange(0,character,digit+1,9))&&(C.hits[character][digit+1]==0)){
                    digit++;
                    return ;
                }
                else
                    match=4;
 
                break;
            case 4:
                if((chekRange(0,character,digit-1,9))&&(C.hits[character][digit-1]==0)){
                    digit--;
                    return ;
                }
                else
                    match=5;
                break;
            }
        }
    if(n==4){
        
            if((*(kor)-*(kor+2))==-1){
            character=*(kor+2);
            digit=*(kor+1);
            }
            if((*(kor)-*(kor+2))==1){
            character=*(kor);
            digit=*(kor+1);
            }
            if((*(kor+1)-*(kor+3))==-1){
            character=*(kor);
            digit=*(kor+3);
            match=3;
            }
            if((*(kor+1)-*(kor+3))==1){
            character=*(kor);
            digit=*(kor+1);
            match=3;
            }
       for(;;){
            switch(match)
            {
            case 1:
                if((chekRange(0,character+1,digit,9))&&(C.hits[character+1][digit]==0)){
                    character++;
                    return ;
                }
                else
                    match=2;
            break;
            case 2:
                if((chekRange(0,character-2,digit,9))&&(C.hits[character-2][digit]==0)){
                    character-=2;
                    return ;
                }
                else
                    match=5;
 
                break;
            case 3:
                if((chekRange(0,character,digit+1,9))&&(C.hits[character][digit+1]==0)){
                    digit++;
                    return ;
                }
                else
                    match=4;
 
                break;
            case 4:
                if((chekRange(0,character,digit-2,9))&&(C.hits[character][digit-2]==0)){
                    digit-=2;
                    return ;
                }
                else
                    match=5;
                break;
            }
        
            if(match==5)
                break;
        }
    }
    if(n==6){
            if((*(kor)-*(kor+2))==0){
            character=*(kor+2);
            digit=*(kor+1);
                if(digit<*(kor+3))
                    digit=*(kor+3);
                if(digit<*(kor+5))
                    digit=*(kor+5);
                match=3;
            }
            if((*(kor+1)-*(kor+3))==0){
            digit=*(kor+1);
            character=*(kor);
                if(character<*(kor+2))
            character=*(kor+2);
                if(character<*(kor+4))
            character=*(kor+4);
            }
 
       for(;;){
            switch(match)
            {
            case 1:
                if((chekRange(0,character+1,digit,9))&&(C.hits[character+1][digit]==0)){
                    character++;
                    return ;
                }
                else
                    match=2;
            break;
            case 2:
                if((chekRange(0,character-3,digit,9))&&(C.hits[character-3][digit]==0)){
                    character-=3;
                    return ;
                }
                else
                    match=5;
 
                break;
            case 3:
                if((chekRange(0,character,digit+1,9))&&(C.hits[character][digit+1]==0)){
                    digit++;
                    return ;
                }
                else
                    match=4;
 
                break;
            case 4:
                if((chekRange(0,character,digit-3,9))&&(C.hits[character][digit-3]==0)){
                    digit-=3;
                    return ;
                }
                else
                    match=5;
                break;
            }
        
            if(match==5)
                break;
        }
    }
 
}
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
//Class_player.cpp
#include "Class_player.h"
player::player (){
        defeat_flag=0;
        
        //крнтсруктор класса player
    }
void player::ships_init(){
        //Инициализация массива ships помещение в него кораблей
        for(int i=0;i<10;i++)
            for(int j=0;j<10;j++){
                hits[i][j]=0;
                ships[i][j]=1;
        }
    for(int i=4;i>0;i--)
            for(int j=i; j<5; j++){
                 set(i);
                  //Вызываем функцию которая устанавливает корабли
 
            }
    }
    void player::set(int deck){
        //Заполнить генератором случ чисел направления и координаты
        //в
    bool doit=true;
        direction d;
    
        
        do {
            if (rand()%2)
                d=h;
            else
                d=v;
 
    int S=rand()%10;    
    int C=rand()%10;
    doit=place_ship(S,C,d,deck);
 
        }while(!doit);
 
    }
    bool player::place_ship(int s,int c, direction dir, int desk){
        //
        //
    //  bool doit=true;
        //for (int i=
        switch(dir){
            case v:
                    if (s>=desk-1)
    {
                if(s==desk-1){
            for(int i=1;i>=-(desk-1);i--)
                for(int j=1;j>=-1;j--){
                    if(((s+i)<0)||((c+j)<0)) continue;
                    if(((s+i)>9)||((c+j)>9)) continue;
    //          cout<<"\n"<<"s+i= "<<s+i<<"  c+j= "<<c+j;
 
                    if(ships[s+i][c+j]==2){
                        return false;
                    }
                }
        }
        if(s>desk-1){
            for(int i=1;i>=-desk;i--)
                for(int j=1;j>=-1;j--){
                    if(((s+i)<0)||((c+j)<0)) continue;
                    if(((s+i)>9)||((c+j)>9)) continue;
    //                  cout<<"\n"<<"s+i= "<<s+i<<"  c+j= "<<c+j;
                    if(ships[s+i][c+j]==2){
                        return false;
 
                    }
                }
        }
 
        for(int i=desk;i>0;i--)
                ships[s-(desk-i)][c]=2;
            return true;
        }
    else
    {
        return false;
    }
                    
                break;
            case h:
    if (c>=desk-1)
    {
        if(c==desk-1){
            for(int i=1;i>=-1;i--)
                for(int j=1;j>=-(desk-1);j--){
                    if(((s+i)<0)||((c+j)<0)) continue;
                    if(((s+i)>9)||((c+j)>9)) continue;
    //          cout<<"\n"<<"s+i= "<<s+i<<"  c+j= "<<c+j;
 
                    if(ships[s+i][c+j]==2){
                        return false;
                    }
                }
        }
        if(c>desk-1){
            for(int i=1;i>=-1;i--)
                for(int j=1;j>=-desk;j--){
                    if(((s+i)<0)||((c+j)<0)) continue;
                    if(((s+i)>9)||((c+j)>9)) continue;
    //                  cout<<"\n"<<"s+i= "<<s+i<<"  c+j= "<<c+j;
                    if(ships[s+i][c+j]==2){
                        return false;
 
                    }
                }
        }
        for(int i=desk-1;i>=0;i--)
                ships[s][(c-i)]=2;
        return true;
    }
    else
    {
        return false;
    }
                break;
        
 
 
    }
    }
    bool player::turn(player& computer, int character,int digit){
 
        if ((computer.ships[character][digit]==2)||(computer.ships[character][digit]==3)){
            computer.ships[character][digit]=3;
            return true;}
        return false;
    }
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
//Funk_for_MB.h
#ifndef _FUNK_FOR_MB_
#define _FUNK_FOR_MB_
 
const int s=13, c=29;
char map[s][c]={
    "  0123456789     0123456789 ",
    " #----------#   #----------#",
    "0|          |  0|          |",
    "1|          |  1|          |",
    "2|          |  2|          |",
    "3|          |  3|          |",
    "4|          |  4|          |",
    "5|          |  5|          |",
    "6|          |  6|          |",
    "7|          |  7|          |",
    "8|          |  8|          |",
    "9|          |  9|          |",
    " #----------#   #----------#"};
 
 
 
void map_init(char map[s][c]);
void map_initC(char map[s][c]);//Техническая Ф-ция для отображения полей Компа
 
void show(char map[s][c]);
 
void input (player& H, char& character,char& digit);
 
void test();
int check_ending();
 
/**/bool chekRange(int St,int _1,int _2,int End);
int IQ (player& human , int Sc,int Cc){
    for(int i=-1;i<2;i++)
        for(int j=-1;j<2;j++)
            if(chekRange(0,Sc+i,Cc+j,9))
                if (human.ships[Sc+i][Cc+j]==2)
                    return 1;
    return 0;
}
void logic_hit (player& C, int Sc,int Cc){
    for(int i=-1;i<2;i++)
        for(int j=-1;j<2;j++)
            if(chekRange(0,Sc+i,Cc+j,9))
                if ((C.hits[Sc+i][Cc+j]!=1)&&(C.hits[Sc+i][Cc+j]!=9))
                    C.hits[Sc+i][Cc+j]=1;
}
 
void input (int& character,int& digit,player& C, int *kor, int n);
/*bool chekRange(int St,int _1,int _2,int End){
    if ((St<=_1)&&(St<=_2))
        if((End>=_1)&&(End>=_2))
            return true;
    return false;
}*/
 
bool ship_die (player& human, int *k, int n){
    int car, dig;
    int count=0;
    for(int i=0; i<n; i++){
        if (i%2==0)
            car=k[i];
        if (i%2==1){
            dig=k[i];
            count+=IQ(human,car,dig);}
    }
    if (count==0)
        return true;
    else 
        return false;
}
void do_after_die (player& human, int *k, int n){
    int car, dig;
    for(int i=0; i<n; i++){
        if (i%2==0)
            car=k[i];
        if (i%2==1){
            dig=k[i];
            logic_hit(human,car,dig);
            }
    }
}
 
#endif //_FUNK_FOR_MB_
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
//Class_player.h 
#ifndef _CLASS_PLAYER_
#define _CLASS_PLAYER_
 
#include <iostream>
#include <stdlib.h>
#include <time.h>
#include <conio.h>
 
enum direction {v=1,h=2};
class player
{
public:
    bool defeat_flag;
    int hits[10][10];// маска попаданий принимает либо 0 либо 1 или 9
    int ships[10][10];// маска кораблей 1-море 2-корабль 3 убитый корабль
    player ();
 
    void ships_init();
    void set(int deck);
bool place_ship(int s,int c, direction dir, int desk);
 
    bool turn(player& computer, int character,int digit);
 
    void forturn(player& computer, int &character,int &digit){
 
         for(;;){
         character=rand()%10;
        digit=rand()%10;
        if((computer.hits[character][digit]==9)||(computer.hits[character][digit]==1))
            continue;
        else 
            break;
         }
 
    }
 
    void defeat(){
        for(int i=0;i<10;i++)
            for(int j=0;j<10;j++)
                if (ships[i][j]==2)
                    return;
            
defeat_flag=true;
return;
    }
 
};
extern  player human;
extern player computer;
 
#endif /*_CLASS_PLAYER_*/
Я так понял здесь на форуме два типа людей, одни профессионалы, которым писать консольные игрушки вообще не надо, они умеют просто не надо. И второй тип это ленивые(ну может времени нету) начинающие , которые просто не доросли, между этими людьми пропасть.
Та вот: Ищу людей которым будет полезно пописать консольные игрушки на Си++ для совместной разработки. И возможно, какого-то толкового профи, который знает, как толково руководить разработкой таких программы.

Я думаю следующую программу я буду писать это консольный тетрис - есть предложения, или умные советы, или толковые ссылки в сети???

Также принимаются замечания по коду морского боя, (зы по нужным файлам функции я еще раскидаю, еще не знаю будет либо 5 либо 7 файлов в проекте). Нужен небольшой анализ на тему какие функции стоило-бы разместить внутри класса(плеер).

Добавлено через 49 минут
Нашел исходник тетриса!
http://p-a2.blogspot.com/2012/04/tetris-c.html
Вот здесь вроде все работает , буду разбирать )
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru