С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 1
Регистрация: 02.10.2014
Сообщений: 3
1

Анализ ситуации на шахматном поле

13.10.2014, 20:27. Показов 914. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте. Есть задача:

Анализ ситуации на шахматном поле. В файле input в любом удобном виде (но в принятой в шахматах нотации - е2, h7 !!!) записан список 4-х имеющихся черных фигур – короля и трех фигур (по вариантам) с указанием положения каждой. Пользователь с клавиатуры задает положение на доске белого короля. Программа должна проверить допустимость этого положения (не занято ли поле черной фигурой?) и в условии хода белых фигур провести анализ игровой ситуации - шах, пат, мат или королям ничего не угрожает. Реализовать класс «Фигура», включающий в себя информацию о положении фигуры на поле и виртуальный метод «Сделать ход». Для различных видов фигур реализовать классы-наследники с соответствующими методами «Сделать ход», просчитывающими множество возможных ходов фигуры. Шахматную доску реализовать статическим двумерным массивом. Вывести на экран образ шахматной доски, где отобразить положение фигур буквами, обозначающими данную фигуру, красным цветом, возможные ходы каждой фигуры – зеленым, остальные клетки доски – белым. В выходном файле должно отражаться название, положение каждой фигуры и анализ игровой ситуации.

Варианты:

1.__Ферзь и два коня
2.__Ферзь и два слона
3.__Ферзь и две ладьи
4.__Ферзь и две пешки
5.__Конь и два слона
6.__Слон и две ладьи
7.__Ладья и две пешки
8.__Пешка и два слона
9.__Ладья и два коня
10._Конь и две пешки

Есть код:

cloud.mail.ru/public/4f5dff035a5a%2Fmain.cpp
 Комментарий модератора 
Выкладывайте код на форуме


При попытке откомпилировать ругается много и часто. Кому не лень подскажите косяки!!!!!
Заранее благодарен!!!


Добавлено через 13 минут
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
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <time.h> 
#include <conio.h>
#include <iostream>
#include <iomanip>
#include <fstream>
#include <string.h>
 
using namespace std;
 
// chess notation
// ферзь два коня король
// Qa3 Nh4 Nc3 Ke5
 
// В обображении фигур на консоли на доске: W - белый король
class figure
{
protected:
int x; // 1..8 like a..h
int y; // 1..8
int a[9][9];
public:
figure(int x_,int y_,int a_[9][9])
{
x=x_;
y=y_;
for (int i=1; i<9; i++)
for (int j=1; j<9; j++)
a[j]=a_[j];
}
 
 
bool is(int i, int j) // попадает ли клетка [i,j] на доску
{
if (i<9 && i>0 && j>0 && j<9)
return true;
return false;
}
 
bool isfight(int x0, int y0) // бьют ли черные фигуры клетку [x0,y0]
{
// координаты черных фигур
int xk,yk; 
int xn[2],yn[2];
int xq,yq;
 
int count=0;
for (int i=1; i<9; i++)
for (int j=1; j<9; j++)
{
if (a[j]==1)
{ xk=i; yk=j;}
if (a[j]==2)
{ xq=i; yq=j;}
if (a[j]==3)
{
xn[count]=i; yn[count]=j;
count++;
}
}
//черный король
if (abs(xk-x0)<=1 && abs(yk-y0)<=1)
return true;
//черный конь
if ( (is(x0+1,y0+2) && a[x0+1][y0+2]==3)
|| (is(x0+1,y0-2) && a[x0+1][y0-2]==3) 
|| (is(x0-1,y0+2) && a[x0-1][y0+2]==3)
|| (is(x0-1,y0-2) && a[x0-1][y0-2]==3)
|| (is(x0+2,y0+1) && a[x0+2][y0+1]==3)
|| (is(x0+2,y0-1) && a[x0+2][y0-1]==3)
|| (is(x0-2,y0+1) && a[x0-2][y0+1]==3)
|| (is(x0-2,y0-1) && a[x0-2][y0-1]==3)
)
return true;
//черный ферзь
 
// горизонтали и вертикали
for (int i=xq+1; i<9; i++)
{
if (x0==i && y0==yq)
return true;
if (a[yq]!=0)
break;
}
for (int i=xq-1; i>0; i--)
{
if (x0==i && y0==yq)
return true;
if (a[yq])
break;
}
for (int j=yq+1; j<9; j++)
{
if (x0==xq && j==y0)
return true;
if (a[xq][j])
break;
}
for (int j=yq-1; j>0; j--)
{
if (x0==xq && j==y0)
return true;
if (a[xq][j])
break;
}
// диагонали
for (int i=1; xq+i<9 && yq+i<9; i++)
{
if (x0==xq+i && y0==yq+i)
return true;
if (a[xq+i][yq+i])
break;
}
for (int i=1; xq-i>0 && yq-i>0; i++)
{
if (x0==xq-i && y0==yq-i)
return true;
if (a[xq-i][yq-i])
break;
}
for (int i=1; xq-i>0 && yq+i<9; i++)
{
if (x0==xq-i && y0==yq+i)
return true;
if (a[xq-i][yq+i])
break;
}
for (int i=1; xq+i<9 && yq-i>0; i++)
{
if (x0==xq+i && y0==yq-i)
return true;
if (a[xq+i][yq-i])
break;
} 
 
return false;
}
 
bool isfight(int x0, int y0, int a[9][9], bool fl) // бьют ли черные фигуры клетку [x0,y0]
// если там черная фигура и никто не бьет,то
// fl
{
// координаты черных фигур
int xk,yk; 
int xn[2],yn[2];
int xq,yq;
 
int count=0;
for (int i=1; i<9; i++)
for (int j=1; j<9; j++)
{
if (a[j]==1)
{ xk=i; yk=j;}
if (a[j]==2)
{ xq=i; yq=j;}
if (a[j]==3)
{
xn[count]=i; yn[count]=j;
count++;
}
}
//черный король
if (abs(xk-x0)<=1 && abs(yk-y0)<=1)
return true;
//черный конь
if ( (is(x0+1,y0+2) && a[x0+1][y0+2]==3)
|| (is(x0+1,y0-2) && a[x0+1][y0-2]==3) 
|| (is(x0-1,y0+2) && a[x0-1][y0+2]==3)
|| (is(x0-1,y0-2) && a[x0-1][y0-2]==3)
|| (is(x0+2,y0+1) && a[x0+2][y0+1]==3)
|| (is(x0+2,y0-1) && a[x0+2][y0-1]==3)
|| (is(x0-2,y0+1) && a[x0-2][y0+1]==3)
|| (is(x0-2,y0-1) && a[x0-2][y0-1]==3)
)
return true;
//черный ферзь
 
// горизонтали и вертикали
for (int i=xq+1; i<9; i++)
{
if (x0==i && y0==yq)
return true;
if (a[yq]!=0)
break;
}
for (int i=xq-1; i>0; i--)
{
if (x0==i && y0==yq)
return true;
if (a[yq])
break;
}
for (int j=yq+1; j<9; j++)
{
if (x0==xq && j==y0)
return true;
if (a[xq][j])
break;
}
for (int j=yq-1; j>0; j--)
{
if (x0==xq && j==y0)
return true;
if (a[xq][j])
break;
}
// диагонали
for (int i=1; xq+i<9 && yq+i<9; i++)
{
if (x0==xq+i && y0==yq+i)
return true;
if (a[xq+i][yq+i])
break;
}
for (int i=1; xq-i>0 && yq-i>0; i++)
{
if (x0==xq-i && y0==yq-i)
return true;
if (a[xq-i][yq-i])
break;
}
for (int i=1; xq-i>0 && yq+i<9; i++)
{
if (x0==xq-i && y0==yq+i)
return true;
if (a[xq-i][yq+i])
break;
}
for (int i=1; xq+i<9 && yq-i>0; i++)
{
if (x0==xq+i && y0==yq-i)
return true;
if (a[xq+i][yq-i])
break;
} 
 
if (a[x0][y0] && a[x0][y0]!=4)
return fl;
return false;
}
 
 
virtual void moves() {}
};
 
class knight: public figure
{
public:
knight(int x_,int y_,int a_[9][9]) : figure(x_,y_,a_) 
{}
 
char xtoc(int x)
{
return (char)(x+96);
}
 
void moves(ofstream &out) 
{
cout<<"moves black knight ("<<xtoc(x)<<y<<"):"<<endl;
out<<"moves black knight ("<<xtoc(x)<<y<<"):"<<endl;
if (is(x+2,y+1) && !a[x+2][y+1])
{
cout<<xtoc(x+2)<<y+1<<" ";
out<<xtoc(x+2)<<y+1<<" ";}
if (is(x+2,y-1) && !a[x+2][y-1])
{cout<<xtoc(x+2)<<y-1<<" ";
out<<xtoc(x+2)<<y-1<<" ";}
if (is(x-2,y+1) && !a[x-2][y+1])
{cout<<xtoc(x-2)<<y+1<<" "; 
out<<xtoc(x-2)<<y+1<<" ";} 
if (is(x-2,y-1) && !a[x-2][y-1])
{cout<<xtoc(x-2)<<y-1<<" ";
out<<xtoc(x-2)<<y-1<<" ";}
 
if (is(x+1,y+2) && !a[x+1][y+2])
{cout<<xtoc(x+1)<<y+2<<" ";
out<<xtoc(x+1)<<y+2<<" ";}
if (is(x+1,y-2) && !a[x+1][y-2])
{cout<<xtoc(x+1)<<y-2<<" "; 
out<<xtoc(x+1)<<y-2<<" ";} 
if (is(x-1,y+2) && !a[x-1][y+2])
{cout<<xtoc(x-1)<<y+2<<" ";
out<<xtoc(x-1)<<y+2<<" ";}
if (is(x-1,y-2) && !a[x-1][y-2])
{cout<<xtoc(x-1)<<y-2<<" "; 
out<<xtoc(x-1)<<y-2<<" ";}
cout<<endl;
out<<endl;
}
};
 
class queen: public figure
{
public:
queen(int x_,int y_,int a_[9][9]) : figure(x_,y_,a_) 
{}
 
char xtoc(int x)
{
return (char)(x+96);
}
 
void moves(ofstream &out) 
{
cout<<"moves black queen:"<<endl;
out<<"moves black queen:"<<endl;
int xq=x;
int yq=y;
for (int i=xq+1; i<9; i++)
{
if (a[yq]!=0)
break;
cout<<xtoc(i)<<yq<<" ";
out<<xtoc(i)<<yq<<" ";
}
for (int i=xq-1; i>0; i--)
{
if (a[yq])
break;
cout<<xtoc(i)<<yq<<" ";
out<<xtoc(i)<<yq<<" ";
}
for (int j=yq+1; j<9; j++)
{
if (a[xq][j])
break;
cout<<xtoc(xq)<<j<<" ";
out<<xtoc(xq)<<j<<" ";
}
for (int j=yq-1; j>0; j--)
{
if (a[xq][j])
break;
cout<<xtoc(xq)<<j<<" ";
out<<xtoc(xq)<<j<<" ";
}
// диагонали
for (int i=1; xq+i<9 && yq+i<9; i++)
{
if (a[xq+i][yq+i])
break;
cout<<xtoc(i+xq)<<yq+i<<" ";
out<<xtoc(i+xq)<<yq+i<<" ";
}
for (int i=1; xq-i>0 && yq-i>0; i++)
{
if (a[xq-i][yq-i])
break;
cout<<xtoc(xq-i)<<yq-i<<" ";
out<<xtoc(xq-i)<<yq-i<<" ";
}
for (int i=1; xq-i>0 && yq+i<9; i++)
{
if (a[xq-i][yq+i])
break;
cout<<xtoc(xq-i)<<yq+i<<" ";
out<<xtoc(xq-i)<<yq+i<<" ";
}
for (int i=1; xq+i<9 && yq-i>0; i++)
{
if (a[xq+i][yq-i])
break;
cout<<xtoc(i+xq)<<yq-i<<" ";
out<<xtoc(i+xq)<<yq-i<<" ";
} 
 
cout<<endl; 
out<<endl;
 
}
};
 
class king: public figure
{
int color;
public:
king(int x_,int y_, int color_,int a_[9][9]) : figure(x_,y_,a_) // color: 1 or 4
{
color=color_;
}
 
char xtoc(int x)
{
return (char)(x+96);
}
 
void moves(ofstream &out) 
{
if (color==1)
{
int xw,yw;
for (int i=1; i<9; i++)
for (int j=1; j<9; j++)
if (a[j]==4)    
{
xw=i; yw=j;
i=9; break;
}
cout<<"moves black king:"<<endl;
out<<"moves black king:"<<endl;
if (is(x+1,y+1) && !a[x+1][y+1] && !(abs(x+1-xw)<=1 && abs(y+1-yw)<=1))
{
cout<<xtoc(x+1)<<y+1<<" ";
out<<xtoc(x+1)<<y+1<<" ";
}
if (is(x+1,y-1) && !a[x+1][y-1] && !(abs(x+1-xw)<=1 && abs(y-1-yw)<=1))
{cout<<xtoc(x+1)<<y-1<<" ";
out<<xtoc(x+1)<<y-1<<" ";}
if (is(x-1,y+1) && !a[x-1][y+1] && !(abs(x-1-xw)<=1 && abs(y+1-yw)<=1))
{cout<<xtoc(x-1)<<y+1<<" ";
out<<xtoc(x-1)<<y+1<<" ";}
if (is(x-1,y-1) && !a[x-1][y-1] && !(abs(x-1-xw)<=1 && abs(y-1-yw)<=1))
{cout<<xtoc(x-1)<<y-1<<" ";
out<<xtoc(x-1)<<y-1<<" ";}
if (is(x,y-1) && !a[x][y-1] && !(abs(x-xw)<=1 && abs(y-1-yw)<=1))
{cout<<xtoc(x)<<y-1<<" ";
out<<xtoc(x)<<y-1<<" ";}
if (is(x,y+1) && !a[x][y+1] && !(abs(x-xw)<=1 && abs(y+1-yw)<=1))
{cout<<xtoc(x)<<y+1<<" ";
out<<xtoc(x)<<y+1<<" ";}
if (is(x+1,y) && !a[x+1][y] && !(abs(x+1-xw)<=1 && abs(y-yw)<=1))
{cout<<xtoc(x+1)<<y<<" ";
out<<xtoc(x+1)<<y<<" ";}
if (is(x-1,y) && !a[x-1][y] && !(abs(x-1-xw)<=1 && abs(y-yw)<=1))
{cout<<xtoc(x-1)<<y<<" ";
out<<xtoc(x-1)<<y<<" ";}
cout<<endl;
out<<endl;
}
else
{
cout<<"moves white king:"<<endl;
out<<"moves white king:"<<endl;
int b[9][9];
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
13.10.2014, 20:27
Ответы с готовыми решениями:

анализ ситуации
Значит странное дело. Освобождается домен - у него ПР=5 ! Весь контент на archive.org !!...

Анализ ситуации с картриджами в организации
Здравствуйте. Пишу в курилку, так как насчет организационных фопросов раздела не нашел. Просьба...

На шахматном поле (k, l) расположен конь. Угрожает ли он полю (m, n)?
Поле шахмотной доски определяется парой натуральных чисел, каждое из которых не превосходит восьми:...

В шахматном порядке
Заполнить двоичную матрицу (состоящую только из нулей и единиц) в шахматном порядке. В левом...

1
0 / 0 / 1
Регистрация: 02.10.2014
Сообщений: 3
13.10.2014, 20:27  [ТС] 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
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
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
if (is(x+1,y+1) && !a[x+1][y+1] && !isfight(x+1,y+1))
{
for (int i=1; i<9; i++)
for (int j=1; j<9; j++)
b[j]=a[j];
b[x][y]=0;
b[x+1][y+1]=4;
 
if (!isfight(x+1,y+1,b,true)) 
{
cout<<xtoc(x+1)<<y+1<<" ";
out<<xtoc(x+1)<<y+1<<" ";}
 
}
if (is(x+1,y-1) && !a[x+1][y-1] && !isfight(x+1,y-1))
{
for (int i=1; i<9; i++)
for (int j=1; j<9; j++)
b[j]=a[j];
b[x][y]=0;
b[x+1][y-1]=4;
 
if (!isfight(x+1,y-1,b,true)) 
{ cout<<xtoc(x+1)<<y-1<<" ";
out<<xtoc(x+1)<<y-1<<" ";}
}
if (is(x-1,y+1) && !a[x-1][y+1] && !isfight(x-1,y+1))
{
for (int i=1; i<9; i++)
for (int j=1; j<9; j++)
b[j]=a[j];
b[x][y]=0;
b[x-1][y+1]=4;
if (!isfight(x-1,y+1,b,true)) 
{cout<<xtoc(x-1)<<y+1<<" ";
out<<xtoc(x-1)<<y+1<<" ";}
}
if (is(x-1,y-1) && !a[x-1][y-1] && !isfight(x-1,y-1))
{
for (int i=1; i<9; i++)
for (int j=1; j<9; j++)
b[j]=a[j];
b[x][y]=0;
b[x-1][y-1]=4;
 
if (!isfight(x-1,y-1,b,true)) 
 
{cout<<xtoc(x-1)<<y-1<<" ";
out<<xtoc(x-1)<<y-1<<" ";}
} 
if (is(x,y-1) && !a[x][y-1] && !isfight(x,y-1))
{
for (int i=1; i<9; i++)
for (int j=1; j<9; j++)
b[j]=a[j];
b[x][y]=0;
b[x][y-1]=4;
 
if (!isfight(x,y-1,b,true)) 
 
{cout<<xtoc(x)<<y-1<<" ";
out<<xtoc(x)<<y-1<<" ";}
}
if (is(x,y+1) && !a[x][y+1] && !isfight(x,y+1))
{
for (int i=1; i<9; i++)
for (int j=1; j<9; j++)
b[j]=a[j];
b[x][y]=0;
b[x][y+1]=4;
 
if (!isfight(x,y+1,b,true)) 
 
{cout<<xtoc(x)<<y+1<<" ";
out<<xtoc(x)<<y+1<<" ";}
}
if (is(x+1,y) && !a[x+1][y] && !isfight(x+1,y))
{
for (int i=1; i<9; i++)
for (int j=1; j<9; j++)
b[j]=a[j];
b[x][y]=0;
b[x+1][y]=4;
 
if (!isfight(x+1,y,b,true)) 
 
{cout<<xtoc(x+1)<<y<<" ";
out<<xtoc(x+1)<<y<<" ";}
}
if (is(x-1,y) && !a[x-1][y] && !isfight(x-1,y))
{
for (int i=1; i<9; i++)
for (int j=1; j<9; j++)
b[j]=a[j];
b[x][y]=0;
b[x-1][y]=4;
 
if (!isfight(x-1,y,b,true)) 
 
{cout<<xtoc(x-1)<<y<<" "; 
out<<xtoc(x-1)<<y<<" "; }
}
 
cout<<endl;
out<<endl;
}
 
}   
};
 
class chess
{
int x; // 1..8 like a..h
int y; // 1..8
int a[9][9]; // 0 - empty, 1 - K black, 2 - Q black, 3 - N black, 4 - K white
bool noerror;
king* bk;
king* wk;
knight* bn1,*bn2;
queen* bq;
ofstream out;
public:
void getxy(char s[3]); // здесь нотация (например, h8). получаем x и y
int notationtotype(char c); // K Q N в 1 2 3 соответственно
void checkstartposition(); // проверка, действительно ли король, два коня и ферзь
chess(char fname[30]);
~chess();
void showboard(); 
bool is(int i, int j); // попадает ли клетка [i,j] на доску
bool isfight(int x0, int y0, bool fl=true); // бьют ли черные фигуры клетку [x0,y0]
// если там черная фигура и никто не бьет,то
// fl
void analyze(); // в какой ситуации находится белый король 
void moves();
};
 
void chess::getxy(char s[3]) // здесь нотация (например, h8). получаем x и y
{   
x=(int)s[0]-96;
y=((int)s[1])-48;
 
if (x<1 || x>8 || y<1 || y>8)
noerror=false;
}
 
int chess::notationtotype(char c) // K Q N в 1 2 3 соответственно
{
if (c=='K' || c=='k' || c=='к' || c=='К')
return 1;
if (c=='Q' || c=='q')
return 2;
if (c=='N' || c=='n')
return 3;
noerror=false;
return 0;
}
 
void chess::checkstartposition() // проверка, действительно ли король, два коня и ферзь
{
int k=0,n=0,q=0;
 
for (int i=1; i<9; i++)
for (int j=1; j<9; j++)
{
if (a[j]==1)
k++;
else if (a[j]==2)
q++;
else if (a[j]==3)
n++;
else if (a[j]!=0)
{
noerror=false;
return;
}
}
if (k!=1 || q!=1 || n!=2)
noerror=false;
}
 
chess::chess(char fname[30])
{
noerror=true;
ifstream in;
out.open("output.txt");
in.open(fname);
if (!in)
{
cout<<"file "<<fname<<": bad open"<<endl;
out<<"file "<<fname<<": bad open"<<endl;
out.close();
noerror=false;
}
else
{
char ps[3];
char wk[3];
int tp;
 
for (int i=1; i<9; i++)
for (int j=1; j<9; j++)
a[j]=0;
out<<"start position: "<<endl;
for (int i=0; i<4 && noerror; i++)
{
in>>ps;
out<<ps<<" ";
strcpy(wk,&ps[1]);
getxy(wk);
 
if (noerror)
{
a[x][y]=notationtotype(ps[0]);
}
else
{
cout<<"bad data in file "<<fname<<endl; 
out<<"bad data in file "<<fname<<endl; 
out.close();
return;
}
}   
in.close();
checkstartposition();
if (!noerror)
{
cout<<"bad start position of black figures from "<<fname<<endl;
out<<"bad start position of black figures from "<<fname<<endl;
out.close();
}
else
{
cout<<"input position of white king (for example, h4): ";
cin>>wk;
out<<"white king: "<<wk<<endl;
getxy(wk);
if (noerror && a[x][y]==0)
a[x][y]=4;
else
{ 
if (!noerror && a[x][y]==0)
{
cout<<"bad input"<<endl;
out<<"bad input"<<endl;
out.close();
}
else
{
cout<<"this position is not empty"<<endl;
out<<"input position is not empty"<<endl;
out.close();
noerror=false;
}
return;
} 
 
int xb,yb;
for (int i=1; i<9; i++)
for (int j=1; j<9; j++)
if (a[j]==1)
{
xb=i;
yb=j; 
i=9;
break;
}
if (abs(x-xb)<=1 && abs(y-yb)<=1)
{
noerror=false;
cout<<"kings can not be side by side"<<endl;
out<<"kings can not be side by side"<<endl;
out.close();
}
} 
}
 
if (noerror)
{
// координаты черных фигур
int xk,yk; 
int xn[2],yn[2];
int xq,yq;
 
int count=0;
for (int i=1; i<9; i++)
for (int j=1; j<9; j++)
{
if (a[j]==1)
{ xk=i; yk=j;}
if (a[j]==2)
{ xq=i; yq=j;}
if (a[j]==3)
{
xn[count]=i; yn[count]=j;
count++;
}
}
 
bk=new king(xk,yk,1,a);
wk=new king(x,y,4,a);
bn1=new knight(xn[0],yn[0],a);
bn2=new knight(xn[1],yn[1],a);
bq=new queen(xq,yq,a);
}
}
 
chess::~chess()
{
delete bk;
delete wk;
delete bn1;
delete bn2;
delete bq;
}
 
void chess::showboard()
{
if (noerror)
{
// x - столбец, y - строка, причем <-> 8-y+1
for (int i=1; i<9; i++)
{
cout<<9-i<<" ";
out<<9-i<<" ";
for (int j=1; j<9; j++)
{
if (a[j][8-i+1]==0)
{ cout<<"-"; out<<"-";}
else if (a[j][8-i+1]==1)
{cout<<"K"; out<<"K";}
else if (a[j][8-i+1]==2)
{cout<<"Q"; out<<"Q";}
else if (a[j][8-i+1]==3)
{cout<<"N"; out<<"N";}
else if (a[j][8-i+1]==4)
{cout<<"W"; out<<"W";}
else
{cout<<"?"; out<<"?";}
 
cout<<" ";
out<<" ";
}
cout<<endl;
out<<endl;
}
 
cout<<" a b c d e f g h"<<endl;
out<<" a b c d e f g h"<<endl;
 
}
}
 
 
bool chess::is(int i, int j) // попадает ли клетка [i,j] на доску
{
if (i<9 && i>0 && j>0 && j<9)
return true;
return false;
}
bool chess::isfight(int x0, int y0, bool fl) // бьют ли черные фигуры клетку [x0,y0]
// если там черная фигура и никто не бьет,то
// fl
{
// координаты черных фигур
int xk,yk; 
int xn[2],yn[2];
int xq,yq;
 
int count=0;
for (int i=1; i<9; i++)
for (int j=1; j<9; j++)
{
if (a[j]==1)
{ xk=i; yk=j;}
if (a[j]==2)
{ xq=i; yq=j;}
if (a[j]==3)
{
xn[count]=i; yn[count]=j;
count++;
}
}
//черный король
if (abs(xk-x0)<=1 && abs(yk-y0)<=1)
return true;
//черный конь
if ( (is(x0+1,y0+2) && a[x0+1][y0+2]==3)
|| (is(x0+1,y0-2) && a[x0+1][y0-2]==3) 
|| (is(x0-1,y0+2) && a[x0-1][y0+2]==3)
|| (is(x0-1,y0-2) && a[x0-1][y0-2]==3)
|| (is(x0+2,y0+1) && a[x0+2][y0+1]==3)
|| (is(x0+2,y0-1) && a[x0+2][y0-1]==3)
|| (is(x0-2,y0+1) && a[x0-2][y0+1]==3)
|| (is(x0-2,y0-1) && a[x0-2][y0-1]==3)
)
return true;
//черный ферзь
 
// горизонтали и вертикали
for (int i=xq+1; i<9; i++)
{
if (x0==i && y0==yq)
return true;
if (a[yq]!=0)
break;
}
for (int i=xq-1; i>0; i--)
{
if (x0==i && y0==yq)
return true;
if (a[yq])
break;
}
for (int j=yq+1; j<9; j++)
{
if (x0==xq && j==y0)
return true;
if (a[xq][j])
break;
}
for (int j=yq-1; j>0; j--)
{
if (x0==xq && j==y0)
return true;
if (a[xq][j])
break;
}
// диагонали
for (int i=1; xq+i<9 && yq+i<9; i++)
{
if (x0==xq+i && y0==yq+i)
return true;
if (a[xq+i][yq+i])
break;
}
for (int i=1; xq-i>0 && yq-i>0; i++)
{
if (x0==xq-i && y0==yq-i)
return true;
if (a[xq-i][yq-i])
break;
}
for (int i=1; xq-i>0 && yq+i<9; i++)
{
if (x0==xq-i && y0==yq+i)
return true;
if (a[xq-i][yq+i])
break;
}
for (int i=1; xq+i<9 && yq-i>0; i++)
{
if (x0==xq+i && y0==yq-i)
return true;
if (a[xq+i][yq-i])
break;
} 
 
if (a[x0][y0] && a[x0][y0]!=4)
return fl;
return false;
}
 
void chess::analyze() // в какой ситуации находится белый король
{
if (noerror)
{
cout<<"analyze position by white king: ";
out<<"analyze position by white king: ";
if (isfight(x,y))
{
if (
(!is(x+1,y+1) || (is(x+1,y+1) && isfight(x+1,y+1))) &&
(!is(x+1,y-1) || (is(x+1,y-1) && isfight(x+1,y-1))) &&
(!is(x-1,y+1) || (is(x-1,y+1) && isfight(x-1,y+1))) &&
(!is(x-1,y-1) || (is(x-1,y-1) && isfight(x-1,y-1))) &&
(!is(x,y+1) || (is(x,y+1) && isfight(x,y+1))) &&
(!is(x,y-1) || (is(x,y-1) && isfight(x,y-1))) &&
(!is(x+1,y) || (is(x+1,y) && isfight(x+1,y))) &&
(!is(x-1,y) || (is(x-1,y) && isfight(x-1,y))) 
)
{
 
cout<<"checkmate"<<endl;
out<<"checkmate"<<endl;
}
else
{
cout<<"check"<<endl;    
out<<"check"<<endl; 
}
}
else
{
if (
(!is(x+1,y+1) || (is(x+1,y+1) && isfight(x+1,y+1))) &&
(!is(x+1,y-1) || (is(x+1,y-1) && isfight(x+1,y-1))) &&
(!is(x-1,y+1) || (is(x-1,y+1) && isfight(x-1,y+1))) &&
(!is(x-1,y-1) || (is(x-1,y-1) && isfight(x-1,y-1))) &&
(!is(x,y+1) || (is(x,y+1) && isfight(x,y+1))) &&
(!is(x,y-1) || (is(x,y-1) && isfight(x,y-1))) &&
(!is(x+1,y) || (is(x+1,y) && isfight(x+1,y))) &&
(!is(x-1,y) || (is(x-1,y) && isfight(x-1,y))) 
)
{
cout<<"stalemate"<<endl;
out<<"stalemate"<<endl;
}
else
{
cout<<"no danger"<<endl;
out<<"no danger"<<endl;
}
}
}
}   
 
void chess::moves()
{
if (noerror)
{
bk->moves(out);
wk->moves(out);
bn1->moves(out);
bn2->moves(out);
bq->moves(out);
out.close();
}
}
 
int main()
{
char fname[30];
strcpy(fname,"input.txt");  
 
chess game(fname);
game.showboard();
game.analyze();
game.moves();
 
cout<<"result saved to output.txt"<<endl;
 
getch();
return 0;
}
0
13.10.2014, 20:27
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
13.10.2014, 20:27
Помогаю со студенческими работами здесь

Попарно в шахматном порядке
Сформировать массив заданной пользователем размерности (не менее 10х10), в котором все нулевые...

Анализ ценных бумаг (построить Гистограмму и провести анализ)
Здравствуйте! Помогите пожалуйста разобраться с заданием. Для исходных данных нужно определить...

Цвета ячеек в шахматном порядке
есть код, который генерирует таблицу умножения, числа которое вводим, помогите раскрасить ячейки в...

Создать матрицу в шахматном порядке из 0 и 5
Помогите создать матрицу из 0 и 5, получается, что условие выполняется только ля последней строки....

Сколько участников в шахматном турнире?
Ребята нужна помощь в решении задачи? Сколько участников в шахматном турнире, если известно, что...

Анализ сетевого трафика используя регрессионный анализ
Не знал, куда написать, MatLAb очень близок этому инструменту (Weka) Многие в курсе, что из...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru