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

Алгоритм проверки - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Перевод кода с Паскаля на С++ http://www.cyberforum.ru/cpp-beginners/thread815047.html
Помогите плиз перевести код с Паскаля на С++, компилятор DEV C++. Буду вам очень благодарен. Код Pascal Var i:longint; n,k:byte; Function F(n:longint):byte; Var s:byte; Begin s:=0; While n>0 do
C++ Вычислить с использованием оператора while Задание: Сделал с помощью for, никак не могу сделать с циклом предусловия -while, просьба помочь. Сам код: #include <cstdlib> #include <iostream> #include <math.h> using namespace std; http://www.cyberforum.ru/cpp-beginners/thread815043.html
Свойства отношений C++
Задали написать программу, которая проверяет свойство отношения: антисимметрия. Проблема в том, что я не могу понять алгоритм самой программы. Помогите пожалуйста написать программу или хотя бы объясните что за чем делать. Заранее спасибо.
работа с массивами в классах C++
Доброго времени суток! Полскажите пожалуйста если мы в программе создаем массив то можем написать так: const int MAX =10; int arr а если мы создаем массив в классе, какой синтаксис? (оператор new - неинтересен) Заранее спасибо!
C++ Бинарное дерево в типизированный файл http://www.cyberforum.ru/cpp-beginners/thread815031.html
Задача над которой бьюсь уже третий день. 1. Сделать базу данных клиентов банка на основе бинарного дерева дерева Сделать методы: добавление клиента в базу модификация данных поиск по ФИО печать данных клиентов, которые имеют срок больше чем заданый
C++ объясните запись Объясните пожалуйста вот эту запись char *str = "Hello, World!"; нужно ли потом освободить память, и в чем различие от char str = {"Hello, World!"}; подробнее

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

Алгоритм проверки - C++

21.03.2013, 21:55. Просмотров 414. Ответов 4
Метки (Все метки)

Всем доброго времени суток!
Есть один код, это как бы шашки. Задача программы определить какие шашки находятся под ударом,какая шашка угрожает другой и сколько их можно побить за один раз одной шашкой. На доске их должно быть всего несколько штук, разных цветов конечно же. Суть в том что цикл не выводит текст с остерегающим текстом и главное никаких ошибок или предупреждений visual не выдает. Ах да, сейчас цикл только на проверку белых шашек, если подскажете в чем проблема скопирую этот же цикл только заменю значение.
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
#include "stdafx.h"
#include <string.h>
#include <iostream>         
#include <conio.h>      
#include <windows.h>
 
using namespace std;
 
struct Pole
{
    char A[8];
    char B[8];
    char C[8];
    char D[8];
    char E[8];
    char F[8];
    char G[8];
    char H[8];
};
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale(0,  "Russian");
    Pole pole[8];
    for(int i=0;i<8;i++)
    {
        strcpy(pole[i].A," ");
        strcpy(pole[i].B," ");
        strcpy(pole[i].C," ");
        strcpy(pole[i].D," ");
        strcpy(pole[i].E," ");
        strcpy(pole[i].F," ");
        strcpy(pole[i].G," ");
        strcpy(pole[i].H," ");
    }
 
strcpy(pole[4].H,"X"); //случайным образом выставленные шашки для проверки
strcpy(pole[3].E,"X"); //случайным образом выставленные шашки для проверки
strcpy(pole[5].G,"O"); //случайным образом выставленные шашки для проверки
strcpy(pole[6].A,"O"); //случайным образом выставленные шашки для проверки
strcpy(pole[6].F,"X"); //случайным образом выставленные шашки для проверки
 
cout<<     ("\n                                    Шашки \n\n\n");
 
 
  cout<<"                 1     2     3     4     5     6     7     8     \n";
  cout<<"              /-----------------------------------------------\\ \n";
  cout<<"              |     |     |     |     |     |     |     |     |\n";
  cout<<"           a  |  "<<pole[0].A<<"  |  "<<pole[1].A<<"  |  "<<pole[2].A<<"  |  "<<pole[3].A<<"  |  "<<pole[4].A<<"  |  "<<pole[5].A<<"  |  "<<pole[6].A<<"  |  "<<pole[7].A<<"  | \n";
  cout<<"              |     |     |     |     |     |     |     |     |\n";
  cout<<"              ------------------------------------------------- \n";    
  cout<<"              |     |     |     |     |     |     |     |     |\n";
  cout<<"           b  |  "<<pole[0].B<<"  |  "<<pole[1].B<<"  |  "<<pole[2].B<<"  |  "<<pole[3].B<<"  |  "<<pole[4].B<<"  |  "<<pole[5].B<<"  |  "<<pole[6].B<<"  |  "<<pole[7].B<<"  | \n";
  cout<<"              |     |     |     |     |     |     |     |     |\n";
  cout<<"              ------------------------------------------------- \n";   
  cout<<"              |     |     |     |     |     |     |     |     |\n";
  cout<<"           c  |  "<<pole[0].C<<"  |  "<<pole[1].C<<"  |  "<<pole[2].C<<"  |  "<<pole[3].C<<"  |  "<<pole[4].C<<"  |  "<<pole[5].C<<"  |  "<<pole[6].C<<"  |  "<<pole[7].C<<"  | \n";
  cout<<"              |     |     |     |     |     |     |     |     |\n";
  cout<<"              ------------------------------------------------- \n";   
  cout<<"              |     |     |     |     |     |     |     |     |\n";
  cout<<"           d  |  "<<pole[0].D<<"  |  "<<pole[1].D<<"  |  "<<pole[2].D<<"  |  "<<pole[3].D<<"  |  "<<pole[4].D<<"  |  "<<pole[5].D<<"  |  "<<pole[6].D<<"  |  "<<pole[7].D<<"  | \n";
  cout<<"              |     |     |     |     |     |     |     |     |\n";
  cout<<"              ------------------------------------------------- \n";   
  cout<<"              |     |     |     |     |     |     |     |     |\n";
  cout<<"           e  |  "<<pole[0].E<<"  |  "<<pole[1].E<<"  |  "<<pole[2].E<<"  |  "<<pole[3].E<<"  |  "<<pole[4].E<<"  |  "<<pole[5].E<<"  |  "<<pole[6].E<<"  |  "<<pole[7].E<<"  | \n";
  cout<<"              |     |     |     |     |     |     |     |     |\n";
  cout<<"              ------------------------------------------------- \n";   
  cout<<"              |     |     |     |     |     |     |     |     |\n";
  cout<<"           f  |  "<<pole[0].F<<"  |  "<<pole[1].F<<"  |  "<<pole[2].F<<"  |  "<<pole[3].F<<"  |  "<<pole[4].F<<"  |  "<<pole[5].F<<"  |  "<<pole[6].F<<"  |  "<<pole[7].F<<"  | \n";
  cout<<"              |     |     |     |     |     |     |     |     |\n";
  cout<<"              ------------------------------------------------- \n";   
  cout<<"              |     |     |     |     |     |     |     |     |\n";
  cout<<"           g  |  "<<pole[0].G<<"  |  "<<pole[1].G<<"  |  "<<pole[2].G<<"  |  "<<pole[3].G<<"  |  "<<pole[4].G<<"  |  "<<pole[5].G<<"  |  "<<pole[6].G<<"  |  "<<pole[7].G<<"  | \n";
  cout<<"              |     |     |     |     |     |     |     |     |\n";
  cout<<"              ------------------------------------------------- \n";   
  cout<<"              |     |     |     |     |     |     |     |     |\n";
  cout<<"           h  |  "<<pole[0].H<<"  |  "<<pole[1].H<<"  |  "<<pole[2].H<<"  |  "<<pole[3].H<<"  |  "<<pole[4].H<<"  |  "<<pole[5].H<<"  |  "<<pole[6].H<<"  |  "<<pole[7].H<<"  | \n";
  cout<<"              |     |     |     |     |     |     |     |     |\n";
  cout<<"              \\-----------------------------------------------/ \n";    
         
int color_select; //выбор цвета шашки которая ходит первой
cout<<"Выберите цвет шашки (1=белая шашка, 2=черная шашка):"; //выбираем вариант 1, цикл есть только для белых
cin>>color_select;
cout<<"Вы выбрали цвет:"<<color_select;
 
 
if (color_select==1)
 {
  for (int i=0; i<8; i++)
    {
        if (pole[i].A=="O")
        {
            if (pole[i-1].B=="X")
                cout<<"Шашка "<<pole[i].A<<" может побить "<<pole[i-1].B;
                if(pole[i+1].B=="X")
                cout<<"Шашка "<<pole[i].A<<" может побить "<<pole[i+1].B;
        }
        if (pole[i].B=="O") 
        {
            if (pole[i-1].A=="X")
                cout<<"Шашка "<<pole[i].B<<" может побить "<<pole[i-1].A;
                if(pole[i+1].A=="X")
                cout<<"Шашка "<<pole[i].B<<" может побить "<<pole[i+1].A;
                if(pole[i+1].C=="X")
                cout<<"Шашка "<<pole[i].B<<" может побить "<<pole[i+1].C;
                if (pole[i-1].C=="X")
                cout<<"Шашка "<<pole[i].B<<" может побить "<<pole[i-1].C;
        }
        if (pole[i].C=="O")
        {
            if (pole[i-1].B=="X")
                cout<<"Шашка "<<pole[i].C<<" может побить "<<pole[i-1].B;
                if(pole[i+1].B=="X")
                cout<<"Шашка "<<pole[i].C<<" может побить "<<pole[i+1].B;
                if(pole[i+1].D=="X")
                cout<<"Шашка "<<pole[i].C<<" может побить "<<pole[i+1].D;
                if (pole[i-1].D=="X")
                cout<<"Шашка "<<pole[i].C<<" может побить "<<pole[i-1].D;
        }
        if (pole[i].D=="O")
            {
            if (pole[i-1].C=="X")
                cout<<"Шашка "<<pole[i].D<<" может побить "<<pole[i-1].C;
                if(pole[i+1].C=="X")
                cout<<"Шашка "<<pole[i].D<<" может побить "<<pole[i+1].C;
                if(pole[i+1].E=="X")
                cout<<"Шашка "<<pole[i].D<<" может побить "<<pole[i+1].E;
                if (pole[i-1].E=="X")
                cout<<"Шашка "<<pole[i].D<<" может побить "<<pole[i-1].E;
            }
        if (pole[i].E=="O")
            {
            if (pole[i-1].D=="X")
                cout<<"Шашка "<<pole[i].E<<" может побить "<<pole[i-1].D;
                if(pole[i+1].D=="X")
                cout<<"Шашка "<<pole[i].E<<" может побить "<<pole[i+1].D;
                if(pole[i+1].F=="X")
                cout<<"Шашка "<<pole[i].E<<" может побить "<<pole[i+1].F;
                if (pole[i-1].F=="X")
                cout<<"Шашка "<<pole[i].E<<" может побить "<<pole[i-1].F;
            }
        if (pole[i].F=="O")
            {
            if (pole[i-1].E=="X")
                cout<<"Шашка "<<pole[i].F<<" может побить "<<pole[i-1].E;
                if(pole[i+1].E=="X")
                cout<<"Шашка "<<pole[i].F<<" может побить "<<pole[i+1].E;
                if(pole[i+1].G=="X")
                cout<<"Шашка "<<pole[i].F<<" может побить "<<pole[i+1].G;
                if (pole[i-1].G=="X")
                cout<<"Шашка "<<pole[i].F<<" может побить "<<pole[i-1].G;
            }
        if (pole[i].G=="O")
            {
            if (pole[i-1].F=="X")
                cout<<"Шашка "<<pole[i].G<<" может побить "<<pole[i-1].F;
                if(pole[i+1].F=="X")
                cout<<"Шашка "<<pole[i].G<<" может побить "<<pole[i+1].F;
                if(pole[i+1].H=="X")
                cout<<"Шашка "<<pole[i].G<<" может побить "<<pole[i+1].H;
                if (pole[i-1].H=="X")
                cout<<"Шашка "<<pole[i].G<<" может побить "<<pole[i-1].H;
            }
        if (pole[i].H=="O")
        {
            if (pole[i-1].G=="X")
                cout<<"Шашка "<<pole[i].H<<" может побить "<<pole[i-1].G;
                if(pole[i+1].G=="X")
                cout<<"Шашка "<<pole[i].H<<" может побить "<<pole[i+1].G;
        }
    }
}
 
getch ();
return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru